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

Формирование Delete и Update запроса для tableAdapter

12.03.2015, 15:45. Показов 2711. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день!
я формирую insert запрос для tableAdapter'ов(каждый адаптер связан со своей таблицей) таким вот образом:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
         private void SqlInsertCommand() {
            _sqlConnection.Open();
            for (int i = 0; i < _mainDataSet.Tables.Count; i++) {
                string cmd = "insert into [" + _mainDataSet.Tables[i].TableName + "] values (";
                for (int j = 0; j < _mainDataSet.Tables[i].Columns.Count; j++)
                    cmd += "@" + _mainDataSet.Tables[i].Columns[j].ColumnName + ", ";
                cmd = cmd.Substring(0, cmd.Length - 2) + ")";
                _allAdapters[i].InsertCommand = new SqlCommand(cmd, _sqlConnection);
                SqlParameterCollection pc = _allAdapters[i].InsertCommand.Parameters;
                for (int j = 0; j < _mainDataSet.Tables[i].Columns.Count; j++)
                    pc.Add("@" + _mainDataSet.Tables[i].Columns[j].ColumnName,
                                parameterType(_mainDataSet.Tables[i].Columns[j].DataType.ToString()), 0,
                                _mainDataSet.Tables[i].Columns[j].ColumnName);
            }
            _sqlConnection.Close();
        }
подскажите, как сформировать delete и update запросы для адаптеров
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
12.03.2015, 15:45
Ответы с готовыми решениями:

Переопределение запросов TableAdapter-a. Запросы UPDATE и DELETE
Изначально не удавалось отредактировать базу. На форумах нашёл, что неободимо посмотреть свойства TableAdaptera. Посмотрел - и...

Update, Insert, Delete для TADOQuery
Как отправлять на сервер запросы Update, Insert и Delete при работе с TADOQuery, если набор данных сформированный Select'ом получен...

TableAdapter.Delete как удалять
Здравствуйте есть несколько вопросов простой пример: 1)у меня есть DataGridView который выводит данные с одной таблицы...

8
 Аватар для kodv
1449 / 1121 / 347
Регистрация: 11.04.2011
Сообщений: 2,621
13.03.2015, 05:50
Лучший ответ Сообщение было отмечено Fene4ka_ как решение

Решение

Fene4ka_, Не изобретайте велосипед - используйте уже готовый.
1
102 / 102 / 40
Регистрация: 24.01.2014
Сообщений: 1,242
13.03.2015, 12:04  [ТС]
kodv, не работает ваша ссылка можете сюда скинуть готовый ?
0
 Аватар для kodv
1449 / 1121 / 347
Регистрация: 11.04.2011
Сообщений: 2,621
13.03.2015, 12:10
https://msdn.microsoft.com/ru-... .110).aspx
1
102 / 102 / 40
Регистрация: 24.01.2014
Сообщений: 1,242
13.03.2015, 12:28  [ТС]
kodv, а можно пример его использования ?
0
 Аватар для kodv
1449 / 1121 / 347
Регистрация: 11.04.2011
Сообщений: 2,621
13.03.2015, 12:46
Fene4ka_, Вы абсрлютно не умеете пользоваться MSDN. Ищете в иерархии нужную реализацию этого абстрактного класса, переходите на страницу описания этой реализации и смотрите там пример. Если предподожить, что ваша БД -MS SQL Server, то пример здесь https://msdn.microsoft.com/ru-... .110).aspx.
0
102 / 102 / 40
Регистрация: 24.01.2014
Сообщений: 1,242
13.03.2015, 12:49  [ТС]
kodv, я сделал вот так:
C#
1
2
3
4
5
            allAdapters.Add(new SqlDataAdapter(@"Select * From " + tableName, conn));
            SqlCommandBuilder builder = new SqlCommandBuilder(allAdapters[allAdapters.Count - 1]);
            allAdapters[allAdapters.Count - 1].InsertCommand = builder.GetInsertCommand();
            allAdapters[allAdapters.Count - 1].DeleteCommand = builder.GetDeleteCommand();
            allAdapters[allAdapters.Count - 1].UpdateCommand = builder.GetUpdateCommand();
но у меня выдает exception, потому что
C#
1
builder.GetInsertCommand();
возвращает Null
0
 Аватар для kodv
1449 / 1121 / 347
Регистрация: 11.04.2011
Сообщений: 2,621
13.03.2015, 13:07
Fene4ka_, В данном случае последние 3 строчки не нужны. DataAdapter сам получит весь набор комманд из CommandBuilder'а. А команды, скорее всего, не формируются из-за отсутствия в таблицах первичных ключей.
1
102 / 102 / 40
Регистрация: 24.01.2014
Сообщений: 1,242
13.03.2015, 13:26  [ТС]
kodv, все работает, спасибо
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
13.03.2015, 13:26
Помогаю со студенческими работами здесь

Отсутствует метод Delete у TableAdapter'a
Подключил базу данных Access, хочу настроить удаление записей из таблицы и столкнулся с тем, что метод Delete() просто напросто...

Как организовать журналирование insert / update / delete для нескольких таблиц?
Используется MySQL - 5.7 - х64 Имеется несколько таблиц с приблизительно следующим кол. и типам полей. Количество полей и...

Объявлена война с TableAdapter.Update
Уже битый час с ним бьюсь. Не поддается. { passNO = Convert.ToInt32(textBox4.Text); passSERIAL =...

TableAdapter.Update() дублирует строки в БД
Здравствуйте Никак не могу понять по какой причине Adapter упорно делает дубли строк в БД с помощью метода Update(). Пример из...

TableAdapter Update не сохраняется последняя строка
Всем привет.В datagridview отображается таблица из БД. В datagridview одна из колонок combobox.Изменения в ней сохраняются с помощью...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru