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

NullReferenceException при редактировании данных

10.12.2018, 01:29. Показов 869. Ответов 3

Студворк — интернет-сервис помощи студентам
Добрый день.
Данная программа работает с базой данных через wf. Пока что реализованы кнопки добавить и редактировать (они выделены цветом) информацию в одну из таблиц. Но при нажатии на "редактировать" появляется ошибка (скрины ниже).
Исходный код прикриплен. University2.rar
Буду благодарна за помощь.


0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
10.12.2018, 01:29
Ответы с готовыми решениями:

lock данных при редактировании
Есть проект на WPF C# LINQ2SQL BindingList + sql2008R2 Необходимо залочить данные на момент их редактирования одним из клиентов. При...

Сохранение изменений в БД при редактировании данных
Создал таблицу с помощью GridControl из комплекта Devexpress https://www.cyberforum.ru/vb-net/thread420939.html Данные отображаются, но...

Ошибка при редактировании данных через DataGridView
Ошибка при редактировании данных через DataGridView. Я создал таблицу с полем id, которое является идентификатором (IDENTITY). Перекинув...

3
 Аватар для XIST
1960 / 1070 / 148
Регистрация: 01.10.2009
Сообщений: 3,593
Записей в блоге: 1
10.12.2018, 08:38
Anna_Stoma, скорре всего ФИО ==null, поставьте точку остановки на нем
0
54 / 48 / 31
Регистрация: 14.04.2015
Сообщений: 273
10.12.2018, 09:00
Anna_Stoma, Прости конечно же но это просто ужас а не код !

C#
1
ff.textBox2.Text = ФИО;
Если не ошибаюсь то ты просто у textBox поставил статус public а это одно из нарушений ООП, если ты о таких слышал.

Так вот чтоб тебе голову не ломать и не искать ошибку, сделай себе модель данных, и работай с ней как хочешь.


// Создай класс с полями из таблицы.
Имя.cs
C#
1
2
3
4
5
6
7
8
9
10
using System;
namespace driver
{
    public class City
    {
        public int IDCity { get; set; }
        public object Start { get; set; }
        public object Finish{ get; set; }
    }
}


// Модель данных еще один класс называй его как хочешь.
DataModel.cs
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
114
115
116
117
using System;
using System.Data.OleDb;
using System.Windows.Forms;
using System.Collections.Generic;
 
namespace driver
{
    class DataModel
    {
        protected string connectString = @"Provider=Microsoft.ACE.OLEDB.12.0;Data Source=driver.accdb;Persist Security Info=False"; // Это путь до баззы данных (На примере у меня БД находиться рядом с exe файлом, путь может быть разный)
 
        private OleDbConnection connect;
        private OleDbDataReader reader;
        private OleDbCommand command;
        
        public List<City> city= new List<City>();        
        
        public void cityDB()
        {
            using (connect = new OleDbConnection(connectString))
            {
                try
                {
                    connect.Open();
                    using (command = new OleDbCommand("select [Код города],[Начальная точка], [Конечная точка] from [Города] order by [Конечная точка]", connect))
                    {
                        using (reader = command.ExecuteReader())
                        {
                            while (reader.Read())
                            {
                                CityList list = new CityList()
                                {
                                    IDCity = int.Parse(reader["Код города"].ToString()),
                                    Start= reader["Начальная точка"],
                                    Finish= reader["Конечная точка"],
                                };
                                city.Add(list);
                            }
                        }
                    }
                }
                catch (Exception ex)
                {
                    MessageBox.Show(ex.Message);
                }
            }
        }
        
        public void cityInsert(string Start, string Finish)
        {
            using (connect = new OleDbConnection(connectString))
            {
                try
                {
                    command = new OleDbCommand("INSERT INTO [Города] ([Начальная точка], [Конечная точка])" +
                    "VALUES (@Start, @Finish)", connect);
 
                    command.Parameters.AddWithValue("@Start", Start);
                    command.Parameters.AddWithValue("@Finish", Finish);
                    connect.Open();
                    if (command.ExecuteNonQuery() == 1)
                    {
                        MessageBox.Show("Запись добавлена", "Информация", MessageBoxButtons.OK, MessageBoxIcon.Information);
                    }
                    connect.Close();
                }
                catch (Exception ex)
                {
                    MessageBox.Show(ex.Message);
                }
            }
        }
        
        public void cityUpdate(string Start, string Finish, int IDCity)
        {
            using (connect = new OleDbConnection(connectString))
            {
                try
                {
                    command = new OleDbCommand("UPDATE [Города] SET [Начальная точка] = ?, [Конечная точка] = ? WHERE [Код города] = ?", connect);
                    command.Parameters.AddWithValue("?", Start);
                    command.Parameters.AddWithValue("?", Finish);
            command.Parameters.AddWithValue("?", IDCity);
                    connect.Open();
                    if (command.ExecuteNonQuery() == 1)
                    {
                        MessageBox.Show("Запись изменена", "Информация", MessageBoxButtons.OK, MessageBoxIcon.Information);
                    }
                    connect.Close();
                }
                catch (Exception ex)
                {
                    MessageBox.Show(ex.Message);
                }
            }
        }
 
        public void cityDelete(int IDCity)
        {
            using (connect = new OleDbConnection(connectString))
            {
                try
                {
                    command = new OleDbCommand("DELETE FROM [Города] WHERE IDCity = ?", connect);
                    command.Parameters.AddWithValue("?", IDCity);
                    connect.Open();
                    if (command.ExecuteNonQuery() == 1)
                    {
                        MessageBox.Show("Запись удалена", "Сообщение", MessageBoxButtons.OK, MessageBoxIcon.Information);
                    }
                    connect.Close();
                }
                catch (Exception ex)
                {
                    MessageBox.Show(ex.Message);
                }
            }


// После чего класс DataModel ты можешь пордключить где угодно и вытянуть данные, к примеру:
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
using System;
using System.Windows.Forms;
 
namespace driver
{
    public partial class autoForm : Form
    {
        
        DataModel model = new DataModel(); // Подключаем класс с нашими функциями и данными.
        
        public autoForm()
        {
            InitializeComponent();
            cityDB();
            
            idLabel.DataBindings.Add("Text", model.auto, "IDCity", false); //Отображаем ID на форме
        }
        // Функция отображения данных на DataGridView
        public void cityDB()
        {
            model.autoDB();
            cityDGV.DataSource = model.city;
            cityDGV.Columns[0].Visible = false;
            cityDGV.Columns[1].HeaderText = "Начальная точка";
            cityDGV.Columns[1].Width = 100;
            cityDGV.Columns[2].HeaderText = "Конечная точка";
            cityDGV.Columns[2].Width = 100;
 
 
 
            cityComboBox.DataSource = model.city; // Подключаешь источник данных
            cityComboBox.ValueMember = "Код города"; // Указываем код города
            autoComboBox.DisplayMember = "Конечная точка"; // Указываем столбец который хотим отобразить
            autoComboBox.SelectedIndex = -1; // Не отображаем первую строку
 
 
        }
        void InsertButtonClick(object sender, EventArgs e)
        {
            model.cityInsert(StartTextBox.Text, FinishTextBox.Text);//Передаем параметры для вставки данных в БД
            updateForm();
        }
        
        void DeleteButtonClick(object sender, EventArgs e)
        {
            model.cityDelete(int.Parse(cityComboBox.SelectedValue.ToString()));// Передаем параметры для удаления записи.
            updateForm();
        }
        //Функция обновления формы
        void updateForm()
        {
            model.city.Clear();
            autoDGV.DataSource = null;
            cityDB();
        }
        
    }
}
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18294 / 14218 / 5368
Регистрация: 17.03.2014
Сообщений: 28,897
Записей в блоге: 1
10.12.2018, 13:09
Anna_Stoma, ошибка возникает потому что форма Редактировать_экзамлист криво сделана. Элементы управления там не инициализируются. Советую пересоздать ее заново.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
10.12.2018, 13:09
Помогаю со студенческими работами здесь

NullReferenceException при передаче данных из формы в базу и datatable
Доброго времени суток уважаемые форумчане! Не судите строго, первый раз задаю вопрос на подобном форуме. Суть вопроса: Пытаюсь...

Поиск данных в БД MySql и NullReferenceException
Здравствуйте! выполняю поиск в базе данных через текст бокс и кнопочку =) Вот само подключение и запрос =: MySqlConnection con = new...

InvalidOperationException при редактировании дочерней таблицы
Всем доброго времени суток! Есть база Access подключенная к проекту через DataSet. В DataGrid выводиться главная таблица и рядом во второй...

Изменить значение при (после) редактировании datatable
Всем привет! Имеется таблица в БД, в ней есть поле DatEdit - &quot;Дата редактирования&quot;. Как сделать на уровне C# заполнение этого поля...

C# DataGridView - добавление в базу при редактировании датагрида
Помогите... есть база даных подключеная к датагриду все работает при запуске отображаютса даные из базы. Никак не могу зделать добавление в...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11680&amp;d=1772460536 Одним из. . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru