Форум программистов, компьютерный форум, киберфорум
C# Windows Forms
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.88/8: Рейтинг темы: голосов - 8, средняя оценка - 4.88
0 / 0 / 0
Регистрация: 10.06.2016
Сообщений: 35

Ссылка на объект не указывает на экземпляр объекта

21.12.2017, 19:12. Показов 1707. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
строка где появляется ошибка
C#
1
dbDataSet.Licenz.FindByIdLic(id).Delete();
Остальной код класса
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
 public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }
        bool DataChanged;
        private void Form1_Load(object sender, EventArgs e)
        {
           
            this.licenzTableAdapter.Fill(this.dbDataSet.Licenz);
                      this.uLTableAdapter.Fill(this.dbDataSet.UL);
            this.vidLicTableAdapter1.Fill(this.dbDataSet.VidLic);
            FillData();
            DataChanged = false;
        }
 
        private void toolStripButton1_Click(object sender, EventArgs e)
        {
           
            try
            {
                licenzTableAdapter.Update(dbDataSet.Licenz);
                dbDataSet.Licenz.AcceptChanges();
                DataChanged = false;
            }
            catch(Exception ex)
            {
                MessageBox.Show("Ошибка при записи в базу данных\n" + ex.Message);
            }
        }
        private void FillData()
        {
            if (!dateTimePicker1.Checked)
                uLLicenzBindingSource.Filter = "";
            else
            {
                string curDate = dateTimePicker1.Value.ToShortDateString();
                uLLicenzBindingSource.Filter = "(dtStart <= '" + curDate + "') AND (dtEnd IS NULL OR dtEnd >= '" + curDate + "')";
            }
            for (int i = 0; i < dataGridView2.RowCount; i++)
                try { dataGridView2["vlName", i].Value = dbDataSet.VidLic.FindByIdVidLic((int)dataGridView2["vidLicDataGridViewTextBoxColumn", i].Value).vlName;
                } catch (Exception ex) { Console.WriteLine(ex); } }
 
        private void dateTimePicker1_ValueChanged(object sender, EventArgs e)
        {
            FillData();
        }
 
        private void toolStripButton2_Click(object sender, EventArgs e)
        {
            NewOkved newOkved = new NewOkved();
            if (newOkved.ShowDialog() != DialogResult.OK)
                return;
            DBDataSet.LicenzRow row = (DBDataSet.LicenzRow)dbDataSet.Licenz.NewRow();
            row.IdUL = (int)dataGridView1["idULDataGridViewTextBoxColumn", dataGridView1.CurrentRow.Index].Value; 
            row.DtStart = DateTime.Parse(newOkved.dateTimePicker1.Value.ToShortDateString());
            if (newOkved.dateTimePicker2.Checked)
                row.DtEnd = DateTime.Parse(newOkved.dateTimePicker1.Value.ToShortDateString());
            row.IdLic = (int)newOkved.dataGridView1["idVidLicDataGridViewTextBoxColumn", newOkved.dataGridView1.CurrentRow.Index].Value; 
            dbDataSet.Licenz.Rows.Add(row);
            dataGridView2["vlName", dataGridView2.RowCount - 1].Value = newOkved.dataGridView1["vlName", newOkved.dataGridView1.CurrentRow.Index].Value;
            uLLicenzdaBindingSource.Position = uLLicenzdaBindingSource.Count - 1;
            DataChanged = true;
        }
 
        private void toolStripButton3_Click(object sender, EventArgs e)
        {
            if (dataGridView2.CurrentRow == null)
                return;
            int ind = dataGridView2.CurrentRow.Index;
            EditOkved editOkved = new EditOkved();
            editOkved.dateTimePicker1.Value = (DateTime)dataGridView2["dtStartDataGridViewTextBoxColumn", ind].Value;
            if (dataGridView2["dtEndDataGridViewTextBoxColumn", ind].Value != DBNull.Value)
                editOkved.dateTimePicker2.Value = (DateTime)dataGridView2["dtEndDataGridViewTextBoxColumn", ind].Value;
            else
                editOkved.dateTimePicker2.Checked = false;
            editOkved.kodOkved = (int)dataGridView2["vidLicDataGridViewTextBoxColumn", ind].Value;
            if (editOkved.ShowDialog() != DialogResult.OK)
                return;
            dataGridView2["dtStartDataGridViewTextBoxColumn", ind].Value = editOkved.dateTimePicker1.Value;
            if (editOkved.dateTimePicker2.Checked)
                dataGridView2["dtEndDataGridViewTextBoxColumn", ind].Value = editOkved.dateTimePicker2.Value;
            else
                dataGridView2["dtEndDataGridViewTextBoxColumn", ind].Value = DBNull.Value; ;
            dataGridView2["vidLicDataGridViewTextBoxColumn", ind].Value = editOkved.checkBox1;
            dataGridView2["vlName", ind].Value = editOkved.nameOkved;
            DataChanged = true;
        }
 
        private void toolStripButton4_Click(object sender, EventArgs e)
        {
            if (dataGridView2.CurrentRow == null)
                return;
            int id = (int)dataGridView2["licOrgDataGridViewTextBoxColumn", dataGridView2.CurrentRow.Index].Value;
            dbDataSet.Licenz.FindByIdLic(id).Delete();
            DataChanged = true;
        }
 
        private void Form1_FormClosing(object sender, FormClosingEventArgs e)
        {
            if (!DataChanged)
                return;
            DialogResult dr =
                MessageBox.Show("Сохранить данные?", "", MessageBoxButtons.YesNoCancel);
            if (dr == DialogResult.No)
                return;
            if (dr == DialogResult.Cancel)
                e.Cancel = true;
            toolStripButton4.PerformClick();
        }
    }
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
21.12.2017, 19:12
Ответы с готовыми решениями:

Ссылка на объект не указывает на экземпляр объекта
Привет Всем! Помогите пожалуйста найти ошибку for (int i = 0; i &lt; dataGridView2.RowCount; i++) dataGridView2.Value = ...

Ссылка на объект не указывает на экземпляр объекта
при нажатии на кнопку выдает ошибку Ссылка на объект не указывает на экземпляр объекта. ошибка в строке 222 learn = x; не могу...

Ссылка на объект не указывает на экземпляр объекта
Имеется рабочая программа WindowsForms, при открытии через EXE файл выдает следующую ошибку. После закрытия, программа работает нормально....

6
 Аватар для ViterAlex
8951 / 4863 / 1886
Регистрация: 11.02.2013
Сообщений: 10,246
21.12.2017, 20:02
Скорее всего метод FindByIdLic ничего не находит, а ты сразу удаляешь.
Нужно так:
C#
1
dbDataSet.Licenz.FindByIdLic(id)?.Delete();
0
0 / 0 / 0
Регистрация: 10.06.2016
Сообщений: 35
22.12.2017, 16:27  [ТС]
Не подскажите, что здесь может быть не так
В столбце "NumLic" не допускаются значения равные nulls.
C#
1
            dbDataSet.Licenz.Rows.Add(row);
Добавлено через 3 минуты
C#
1
 dbDataSet.Licenz.FindByIdLic(id)?.Delete();
Теперь ничего не происходит
0
 Аватар для ViterAlex
8951 / 4863 / 1886
Регистрация: 11.02.2013
Сообщений: 10,246
22.12.2017, 16:56
Цитата Сообщение от 1s55 Посмотреть сообщение
В столбце "NumLic" не допускаются значения равные nulls.
Значит, что таблица базы данных имеет правило, в соответствии с которым, это поле не может быть пустым
Цитата Сообщение от 1s55 Посмотреть сообщение
Теперь ничего не происходит
А что должно происходить?
0
0 / 0 / 0
Регистрация: 10.06.2016
Сообщений: 35
22.12.2017, 17:41  [ТС]
Цитата Сообщение от ViterAlex Посмотреть сообщение
Значит, что таблица базы данных имеет правило, в соответствии с которым, это поле не может быть пустым

А что должно происходить?
Цитата Сообщение от ViterAlex Посмотреть сообщение
А что должно происходить?
Должно происходить удаление строки
0
 Аватар для ViterAlex
8951 / 4863 / 1886
Регистрация: 11.02.2013
Сообщений: 10,246
22.12.2017, 17:52
До этого вылетало NullReferenceException. Если после использования оператора ?. исключение не появляется, значит моё предложение было верно: метод FindByIdLic ничего не возвращает. Значит и удалять нечего
0
0 / 0 / 0
Регистрация: 10.06.2016
Сообщений: 35
23.12.2017, 22:48  [ТС]
Цитата Сообщение от ViterAlex Посмотреть сообщение
Значит, что таблица базы данных имеет правило, в соответствии с которым, это поле не может быть пустым
В моей базе нет таблицы NumLic, но в таблице Licenz есть такое поле и для него установлено свойство, позволяющее иметь пустое значение

Добавлено через 3 минуты
И при нажатии на кнопку вставить велетает "System.Data.NoNullAllowedException"
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
23.12.2017, 22:48
Помогаю со студенческими работами здесь

Ссылка на объект не указывает на экземпляр объекта
Есть кнопка, при нажатии на нее нужно показать длину массива Выбивает ошибку &quot;ссылка на объект не указывает на экземпляр...

Ссылка на объект не указывает на экземпляр объекта
Всем привет! Мне необходимо написать следующее приложение: на форме один по периметру бегает Label и плавно меняет свой цвет. На второй...

Ссылка на объект не указывает на экземпляр объекта
Все объявил, каждой переменной и каждому методу присвоил значения. Однако выходит эта ошибка. Задача программы такая. После нажатия на...

Ссылка на объект не указывает на экземпляр объекта
я совсем недавно начал программировать, пишу проектную работу. Все пишется как по маслу но сталкиваюсь со странными пугающими меня...

Ссылка на объект не указывает на экземпляр объекта
Помогите с кодом! public string prihod; private void dataGridView1_CellContentDoubleClick(object sender,...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru