|
2 / 2 / 1
Регистрация: 17.11.2013
Сообщений: 72
|
||||||
Удаление записи из БД и DataGridView05.10.2014, 13:12. Показов 8233. Ответов 12
Метки нет (Все метки)
Здравствуйте уважаемые программисты, просьба такая: не получается удалить запись из базы данных, имеется DataGridView, отображающий данные из таблицы в БД, но при выполнении метода удаления ничего не происходит и нужная запись не удаляется...
0
|
||||||
| 05.10.2014, 13:12 | |
|
Ответы с готовыми решениями:
12
Удаление записи в DataGridView из БД Программное удаление записи из БД Acess через Datagridview
|
|
1449 / 1121 / 347
Регистрация: 11.04.2011
Сообщений: 2,621
|
|
| 06.10.2014, 06:31 | |
|
Ilyko, где гарантия того, что в метод будет передан id текущей записи из DataGridView? У вас, по идее, id должен хранится в строке данных, может его от туда читать?
Оберните cmd.ExecuteNonQuery() в try-catch, и посмотрите, валятся ли исключения при выполнении команды. если try-catch ен стоит, то исключения из команд просто глотаются и выполнение текущего метода малча прерывается. Если исчлючений нет, то посмотрите в дебагере, какой текст по итогу присваивается строке sSqlCommand, и выполните его напрямую на базе данных.
1
|
|
|
2 / 2 / 1
Регистрация: 17.11.2013
Сообщений: 72
|
||
| 06.10.2014, 11:33 [ТС] | ||
|
буду Вам очень благодарен, если проверете. Проект прикладываю. форма "FormCustomers"
0
|
||
|
1449 / 1121 / 347
Регистрация: 11.04.2011
Сообщений: 2,621
|
|
| 06.10.2014, 12:30 | |
|
Ilyko, Нет возможности проверить [не]работоспособность вашего кода, так как у меня нет вашего SQL Server'а. Какое значение возвращает cmd.ExecuteNonQuery()? 0?
Что касается _id хочу отметить 2 момента: 1. Если вы напрямую используете свойство DataGridCustomers.CurrentRow.Index в своем методе DelFieldFormCustomers для удлаения записи из грида, и косвенно, передавая его в виде параметра _id, для удаления записи из таблицы БД, то почему бы вам не использовать DataGridCustomers.CurrentRow.Index и там и там и удалить параметр _id нафиг? 2. Свойство Index у строки в DataGridView не имеет никакой связи с Id в базе данных. Надеяться на то, что запись с id'ом 500 будет всегда располагаться на 500 позиции в гриде не стоит. Если вы удалите запись с id'ом 300, то запись с id'ом 500 окажется на позиции 499. И вы будете удалять из грида запись с id'ом 500, а из грида с id'ом 499.
1
|
|
|
2 / 2 / 1
Регистрация: 17.11.2013
Сообщений: 72
|
||||||||
| 06.10.2014, 13:02 [ТС] | ||||||||
|
Добавлено через 3 минуты
0
|
||||||||
|
1449 / 1121 / 347
Регистрация: 11.04.2011
Сообщений: 2,621
|
|||||||||||||
| 06.10.2014, 13:04 | |||||||||||||
|
Добавлено через 1 минуту
1
|
|||||||||||||
|
2 / 2 / 1
Регистрация: 17.11.2013
Сообщений: 72
|
||
| 06.10.2014, 13:09 [ТС] | ||
|
Не совсем понял, какой profiler
Добавлено через 3 минуты
0
|
||
|
1449 / 1121 / 347
Регистрация: 11.04.2011
Сообщений: 2,621
|
|||
| 06.10.2014, 13:21 | |||
ну и сразу еще следующий - (int)((DataRowView)bs.Current)["cust_id"] =) На нем можно будет оставноиться. С гридом в коде нужно вести минимальную работу - он служит только для отображения данных.
0
|
|||
|
2 / 2 / 1
Регистрация: 17.11.2013
Сообщений: 72
|
|||||||
| 06.10.2014, 13:32 [ТС] | |||||||
|
Что-то не так или я не догоняю, ошибка "Error 1 Cannot apply indexing with [] to an expression of type 'System.Windows.Forms.DataGridViewRow' " вот кстати мой метод заполнения грида :
0
|
|||||||
|
1449 / 1121 / 347
Регистрация: 11.04.2011
Сообщений: 2,621
|
|
| 06.10.2014, 13:50 | |
|
Ilyko, надо было сразу к варианту с bs переходить) По-моему там еще свойство Cells должно быть: (int)DataGridCustomers.CurrentRow.Cells["cust_id"]. Сейчас с телефона - проверит не могу)
0
|
|
|
2 / 2 / 1
Регистрация: 17.11.2013
Сообщений: 72
|
||
| 06.10.2014, 13:53 [ТС] | ||
|
Хотя я согласен переписать все заново, так что там насчет BindingSource ? и кода написал пока всего-ничего. Но сижу уже 2 дня парюсь
0
|
||
|
1449 / 1121 / 347
Регистрация: 11.04.2011
Сообщений: 2,621
|
||
| 06.10.2014, 14:39 | ||
1
|
||
|
2 / 2 / 1
Регистрация: 17.11.2013
Сообщений: 72
|
||
| 06.10.2014, 15:22 [ТС] | ||
|
0
|
||
| 06.10.2014, 15:22 | |
|
Помогаю со студенческими работами здесь
13
Узнать номер записи в DataTable по выбраной записи в DataGridView Удаление записи списка из DataGridView
Удаление записи из DataGridView и из файла Удаление выделенной записи из DataGridView и Базы Данных Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
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&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 секунды (а то и больше),. . .
|