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

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

23.12.2017, 15:36. Показов 995. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет значение производной при заданном х Логарифм записывается как: (x-2)log(x^2+2) -. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru