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

SqlDataAdapter не обновляет таблицу

23.12.2017, 15:36. Показов 974. Ответов 1

Студворк — интернет-сервис помощи студентам
Доброго времени суток. Перерыл все, испробовал все варианты, SqlDataAdapter отказывается обновлять данные.
Мой класс работы с БД:
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
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
using System;
using System.Data;
using System.Windows.Forms;
using System.Data.SqlClient;
 
namespace NotebookHelper
{
    public class ConnectorMicrosoftSQLServer
    {
        //Строка подключения
        public SqlConnection conn;
 
        public bool CheckException;
 
        public DataTable dataTable;
        public SqlDataAdapter adap;
        public DataSet ds;
        public SqlCommandBuilder commBuild;
 
        //Бинсорсы для таблиц
        public BindingSource binSourceScreen = new BindingSource();
        public BindingSource binSourceProcessor = new BindingSource();
        public BindingSource binSourceVideoCard = new BindingSource();
        public BindingSource binSourceMemory = new BindingSource();
        public BindingSource binSourceMotherboard = new BindingSource();
        public BindingSource binSourceWinchester = new BindingSource();
        public BindingSource binSourceComputerCase = new BindingSource();
        public BindingSource binSourceKeyboard = new BindingSource();
        public BindingSource binSourceComputerFull = new BindingSource();
 
        public BindingSource binSourceCountry = new BindingSource();
        public BindingSource binSourceCompany = new BindingSource();
        public BindingSource binSourceUsers = new BindingSource();
 
        /*Процедуры*/
        //Процедура коннекта к базе
        public bool Connection(string Connection)
        {
            try
            {
                conn = new SqlConnection(Connection);
                conn.Open();
            }
            catch
            {
                return false;
            }
            return true;
        }
 
        //Процедура закрытия коннекта
        public bool CloseConnection()
        {
            conn.Close();
            return true;
        }
 
        //Вернет true, если есть записи
        public bool QueryToBool(string QueryString)
        {
            dataTable = new DataTable();
            SqlCommand com;
            SqlDataReader dataReader;
            com = new SqlCommand(QueryString, conn);
            try
            {
                dataReader = com.ExecuteReader();
            }
            catch (Exception exc)
            {
                MessageBox.Show(exc.Message);
                CheckException = true;
                return false;
            }
            if (dataReader.HasRows)
            {
                dataTable.Load(dataReader);
 
                dataReader.Close();
                com.Dispose();
                return true;
            }
            dataReader.Close();
            com.Dispose();
            CheckException = false;
            return false;
        }
 
        //Процедура подтверждения изменений в таблице
        public void SaveTable(string NameTable)
        {
            if (MessageBox.Show("Вы действительно хотите сохранить?",
                        "Сообщение", MessageBoxButtons.YesNo, MessageBoxIcon.Question) == DialogResult.Yes)
            {
                try
                {
                    commBuild = new SqlCommandBuilder(adap);                   
                    adap.UpdateCommand = commBuild.GetUpdateCommand();
                    adap.Update(ds, NameTable);
 
                    MessageBox.Show("Данные сохранены!", "Сохранение", MessageBoxButtons.OK, MessageBoxIcon.Information);
                }
                catch (Exception exc)
                {
                    MessageBox.Show(exc.Message, "Ошибка", MessageBoxButtons.OK, MessageBoxIcon.Error);
                }
            }
        }
 
        //Процедура загрузки таблицы
        public void LoadTable(string NameTable, string QueryString, BindingSource binSource, DataGridView dataGrid, BindingNavigator Navigator)
        {
            try
            {
                adap = new SqlDataAdapter(QueryString, conn);
                ds = new DataSet();
                adap.Fill(ds, NameTable);
                binSource.DataSource = ds.Tables[0];
                Navigator.BindingSource = binSource;
                dataGrid.DataSource = binSource;
            }
            catch (Exception exc)
            {
                MessageBox.Show(exc.Message, "Ошибка", MessageBoxButtons.OK, MessageBoxIcon.Error);
            }
        }
 
        //Процедура для агрегатных запросов
        public string AgregateQueryToDataGrid(string QueryString)
        {
            int iResultQuery = 0;
            string resultQuery = "";
            SqlCommand com;
            SqlDataReader dataReader;
            com = new SqlCommand(QueryString, conn);
            try
            {
                dataReader = com.ExecuteReader();
            }
            catch (Exception exc)
            {
                MessageBox.Show(exc.Message, "Ошибка", MessageBoxButtons.OK, MessageBoxIcon.Error);
                return resultQuery;
            }
 
            dataReader.Read();
 
            //Пытаемся читать значение которое пришло, обычно это стринг, если нет, то ловим исключение
            try
            {
                resultQuery = dataReader.GetString(0);
            }
            //Поймали исключение и читаем не текст, а число
            catch (Exception)
            {
                //Необработанное исключение типа "System.InvalidOperationException" в System.Data.dll
                iResultQuery = dataReader.GetInt32(0);
                resultQuery = Convert.ToString(iResultQuery);
            }
 
            dataReader.Close();
            com.Dispose();
            return resultQuery;
        }
 
        //Процедура вывода в комбо бокса столбца таблицы
        public bool QueryToComboBox(string QueryString, ComboBox comboBox, string Name_Column)
        {
            dataTable = new DataTable();
            SqlCommand com;
            SqlDataReader dataReader;
            com = new SqlCommand(QueryString, conn);
            try
            {
                dataReader = com.ExecuteReader();
            }
            catch (Exception exc)
            {
                MessageBox.Show(exc.Message);
                return false;
            }
            if (dataReader.HasRows)
            {
                dataTable.Load(dataReader);
                comboBox.DataSource = dataTable;
                comboBox.DisplayMember = Name_Column;
 
                dataReader.Close();
                com.Dispose();
                return true;
            }
            dataReader.Close();
            com.Dispose();
            return false;
        }
 
        //Процедура загрузки таблицы
        public bool LoadTableToDataGridView(string QueryString, BindingSource binSource, DataGridView dataGrid, BindingNavigator Navigator)
        {
            SqlCommand myCommand;
            SqlDataReader dataReader;
            myCommand = new SqlCommand(QueryString, conn);
            try
            {
                dataReader = myCommand.ExecuteReader();
            }
            catch (Exception)
            {
                return false;
            }
            dataTable = new DataTable();
            dataTable.Load(dataReader);
            dataGrid.AutoGenerateColumns = true;
            dataGrid.Refresh();
            binSource.DataSource = dataTable;
            Navigator.BindingSource = binSource;
            dataGrid.DataSource = dataTable;
            dataReader.Close();
            myCommand.Dispose();
 
            return true;
        }
    }
}
Когда открывается форма идет загрузка LoadTable процедуры. Потом Я открываю таблицу Users, и пробую изменить данные, после чего жму на кнопку сохранить, эта кнопка в свою очередь вызывает метод SaveTable(string NameTable), который не изменяет данные в БД, что Я делаю не так?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
23.12.2017, 15:36
Ответы с готовыми решениями:

Не обновляет таблицу
В самом последнем запросе почему то записывается пустота, то есть был <Null> стало "". Я в пхп новичок, и что то не могу понять...

Не обновляет таблицу. Какие могут быть причины?
Люди, здравствуйте. Создаю подключение через MSQuery. Потом меню текст запроса, адресную строку (у меня там только ДСН и был...

Как создать триггер который обновляет запись в таблицы при добавлении записи в другую таблицу
Всем привет, нужна помощь с триггером, столкнулся с ним в первые до этого использовал процедуры, а диплом горит) История такая: ...

1
360 / 287 / 76
Регистрация: 21.06.2016
Сообщений: 1,115
24.12.2017, 22:50
1. Не закрываете соединение, return выходит из процедуры, пока соединение открыто.
2. Адаптер автоматом обновляет таблцу, если подтягивает первичный ключ. Он есть?
3. Поставьте точку остановки в момент определения update команды, и проверьте, что в ней.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
24.12.2017, 22:50
Помогаю со студенческими работами здесь

запрос к БД от SqlDataAdapter
Вызовом метода Update() класса SqlDataAdapter можно зафиксировать все изменения произведенные в таблицах DataTable. Допустим в таблице были...

sqlDataAdapter и sqlCommand
Начал осваивать asp.net по книге Анатолий Постолит Разработка приложений бд, там описывается подключение к бд mssql , через компоненты...

Работа с sqlDataAdapter
У меня не получается получить данные запроса. Я выполняю запрос и хочу присвоить результат на переменную для дальнейши манипуляций! Какими...

SqlDataAdapter не заполняет Dataset
Пытаюсь заполнить типизированный Dataset для банальной Northwind, но безрезультатно. SqlDataAdapter.Fill() возвращает количество...

SqlDataAdapter надо ли закрывать
Добрый день товарищи ! возник такой вопрос. вот обычное подключение к базе и чтение и заполнение datagrid (из книги взят) ...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru