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

NullReferenceException при передаче данных из формы в базу и datatable

23.05.2012, 12:05. Показов 1074. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток уважаемые форумчане!
Не судите строго, первый раз задаю вопрос на подобном форуме.

Суть вопроса:
Пытаюсь передать данные из формы в базу и в datatable.
В этой строчке получаю NullReferenceException:
C#
1
tasksListDA.UpdateCommand.Parameters.Add(new SqlParameter ("@Наименование", SqlDbType.NVarChar));
Ключевое слово new у меня присутствует и объект tasksListDA тоже.
Не могу понять, какой объект я не создал.

Вот код формы:

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
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Data.SqlClient;
 
namespace Registration_Tasks_new
{
    public partial class fAdd_Task : Form
    {
        public fAdd_Task()
        {
            InitializeComponent();
            tbID.Text = (this.tasksTableAdapter1.NextID()).ToString();
        }
 
        private void btCancel_Click(object sender, EventArgs e)
        {
 
            this.Close();
            
        }
 
        private void fAdd_Task_Load(object sender, EventArgs e)
        {
            // TODO: This line of code loads data into the 'registration_Tasks_newDataSet1.Persons' table. You can move, or remove it, as needed.
            this.personsTableAdapter.Fill(this.registration_Tasks_newDataSet1.Persons);
            // TODO: This line of code loads data into the 'registration_Tasks_newDataSet1.Persons' table. You can move, or remove it, as needed.
            this.personsTableAdapter1.Fill(this.registration_Tasks_newDataSet.Persons);
            //this.tasksTableAdapter1.Fill(this.registration_Tasks_newDataSet.Tasks);
        }
 
        private void btAdd_Click(object sender, EventArgs e)
        {            
            SqlConnection connection = new SqlConnection(@"Data Source=homecomputer;Initial Catalog=Registration_Tasks_new;"+
                                                          "Integrated Security=True");
            SqlCommand selectCommand = new SqlCommand(@"SELECT ID, Title_Task, Scope_of_work," +
                                                       "Date_Start, Date_End, Status, Person FROM Tasks", connection);
            SqlDataAdapter tasksListDA = new SqlDataAdapter();
            connection.Open();
            tasksListDA.SelectCommand = selectCommand;
            DataTable newRegTaskNewDS = new DataTable();
            tasksListDA.Fill(newRegTaskNewDS);
 
            DataRow addRow = newRegTaskNewDS.NewRow();
            addRow["Title_Task"] = tbTaskTitle.Text;
            addRow["Scope_of_work"] = int.Parse(tbScopeOfWork.Text);
            addRow["Date_Start"] = dtpDataStart.Value;
            addRow["Date_End"] = dtpDataEnd.Value;
            addRow["Status"] = combobStatus.Text;
            addRow["Person"] = combobPerson.Text;
            newRegTaskNewDS.Rows.Add(addRow);
            
            tasksListDA.SelectCommand = selectCommand;
 
            DataTable changedRegTasksDS = new DataTable();
            changedRegTasksDS = newRegTaskNewDS.GetChanges();
            SqlCommand updateCommand = new SqlCommand(@"UPDATE [Tasks] SET [Title_Task] = @Наименование, [Scope_of_work] = @Работа, [Date_Start] = @Дата_начала, [Date_End] = @Дата_окончания, [Status] = @Статус, [Person] = @Исполнитель WHERE (([ID] = @Original_Идентификатор) AND ([Scope_of_work] = @Original_Работа) AND ((@IsNull_Дата_начала = 1 AND [Date_Start] IS NULL) OR ([Date_Start] = @Original_Дата_начала)) AND ((@IsNull_Дата_окончания = 1 AND [Date_End] IS NULL) OR ([Date_End] = @Original_Дата_окончания)) AND ([Status] = @Original_Статус) AND ((@IsNull_Исполнитель = 1 AND [Person] IS NULL) OR ([Person] = @Original_Исполнитель)));
SELECT ID AS Идентификатор, Title_Task AS Наименование, Scope_of_work AS Работа, Date_Start AS Дата_начала, Date_End AS Дата_окончания, Status AS Статус, Person AS Исполнитель FROM Tasks WHERE (ID = @ID)", connection);
             
            tasksListDA.UpdateCommand.Parameters.Add(new SqlParameter ("@Наименование", SqlDbType.NVarChar));
            tasksListDA.UpdateCommand.Parameters.Add(new SqlParameter("@Работа", SqlDbType.Int));
            tasksListDA.UpdateCommand.Parameters.Add(new SqlParameter("@Дата_начала", SqlDbType.DateTime));
            tasksListDA.UpdateCommand.Parameters.Add(new SqlParameter("@Дата_окончания", SqlDbType.DateTime));
            tasksListDA.UpdateCommand.Parameters.Add(new SqlParameter("@Статус", SqlDbType.NVarChar));
            tasksListDA.UpdateCommand.Parameters.Add(new SqlParameter("@Исполнитель", SqlDbType.NVarChar));
 
            tasksListDA.UpdateCommand = updateCommand;
            tasksListDA.Update(changedRegTasksDS);
 
            DataTable newTasksDataTable = new DataTable();
            newTasksDataTable.Merge(changedRegTasksDS);
            newTasksDataTable.AcceptChanges();
            connection.Close();
        }
    }
}
Помогите, пожалуйста разобраться.
Заранее спасибо за внимание.
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
23.05.2012, 12:05
Ответы с готовыми решениями:

Проблемы при передаче данных из формы на странице в Базу данных
(ASP.NET + MySql) У меня есть на странице текстбокс. Я ввожу туда слово кириллицей и после этого выполняю запрос UPDATE TableName SET...

При передаче данных по локальной сети на сервер в базу sql передается только часть данных
Всем доброго времени суток! У меня ситуация такая – есть своя программа на Delphi 2010 для перегонки данных из html-файлов в базу на sql...

Спец символы при передаче данных в базу
Все доброго, Приложение на J2EE передает данные в базу, если в стринговое поле ввести спец символ типа ' , то появляется ошибка базы...

2
 Аватар для Lasur
267 / 257 / 43
Регистрация: 18.03.2012
Сообщений: 506
23.05.2012, 12:17
C#
1
tasksListDA.UpdateCommand
не инициализирован.
0
beginerdotnet
23.05.2012, 15:05
Спасибо за ответ.
Только теперь появилась еще одна проблема.

Теперь в строчке:
C#
1
tasksListDA.Update(changedRegTasksDS);
возникает InvalidOperationExeption
с текстом Update requires a valid InsertCommand when passed DataRow collection with new rows.

Попробовал заменять UpdateCommand на InsertCommand, но так тоже не вышло.
Подскажите, пожалуйста куда копать!
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
23.05.2012, 15:05
Помогаю со студенческими работами здесь

Ошибки при передаче DataTable
Есть сервис и клиент все работает нормально на простых данных, например строках, но мне нужно передать datatable, при попытке это сделать...

При передаче данных через AJAX не передаются некоторые поля формы
Я новичок, так что сильно не плюйтесь )) Возникла проблема при передаче данных формы обработчику AJAXом. Собственно, форма ...

Ссылка на объект не указывает на экземпляр объекта при передаче данных в DGV другой формы
Здравствуйте уважаемые знатоки, извиняюсь если не туда пишу, новую тему не хочеться заводить, я недавно стал изучать язык C#, и вопросов...

Каскадное удаление при передаче обновлений в базу данных в случае ограничения типа "слоновье ухо"
Здравствуйте, господа. Возник вопрос - может кто подсткажет? В технологии ADO.NET как решается проблема передачи в базу данных...

Вывод данных из DataTable в базу данных SQL Server 2005
Доброго времени суток. Существует таблица DataTable dt = new DataTable(); Как передать данные из этой таблици в sql server 2005?


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
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 з-ны. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru