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

Как удалить запись по его ID?

10.12.2017, 01:29. Показов 3763. Ответов 33
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам

Не по теме:

Не знаю как тему лучше назвать



Есть база данных на access, в ней есть поле ID типа счетчик и я не знаю как удалить ту или иную запись (пользователь сам выбирает) по номеру её ID.

Вначале хотел, чтоб при выборе записи данные заносились в textbox и уже обращаясь к textbox'у я бы удалят нужные мне записи:
C#
1
sda = new OleDbDataAdapter("DELETE FROM Change WHERE ID = '" + textbox.text + "' ", con);
Понятное дело он стал ругаться на несоответствие типов данных. Затем я решил обращаться напрямую к дбгриду тыкнув на него курсором
C#
1
 sda = new OleDbDataAdapter("DELETE FROM Change WHERE ID = '"+ dataGridView3.CurrentRow.Cells["ID"] + "' ", con);
Короче, ошибку точно такую же выдает: "Несоответствие типов данных в выражении условия отбора".

Объясните пожалуйста как удалять записи подобным образом или в какой тип данных нужно конвертировать?
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
10.12.2017, 01:29
Ответы с готовыми решениями:

Как удалить вот этот вирус ieunitdrf.inf антивирусники пробывал всякие не могут его удалить
у меня браузер хором ваще не грузит и мозила постоянно вылетает сижу щас с оперы это все по ходу и за файла ieunitdrf.inf помогите...

Четыре кнопки на форме: добавить запись, удалить запись, закрыть, найти запись
Private Sub КнопкаДобавитьЗапись_Click() On Error GoTo Err_КнопкаДобавитьЗапись_Click DoCmd.GoToRecord , , acNewRec ...

Как удалить запись из БД по id
Здравствуйте. У меня есть БД статей, и страница где выводятся все статьи вместе, причем в каждой есть своя кнопка удалить статью. Написано...

33
3566 / 2507 / 1174
Регистрация: 14.08.2016
Сообщений: 8,219
10.12.2017, 01:34
Цитата Сообщение от sonoramel Посмотреть сообщение
удалить ту или иную запись (пользователь сам выбирает) по номеру её ID
крайне неправильный подход... id не для манипуляций, а-ля удаление, он для другого = забудь что он !!!существует!!!
надо удалить? удали то, что надо...
0
0 / 0 / 1
Регистрация: 01.11.2017
Сообщений: 28
10.12.2017, 01:36  [ТС]
Цитата Сообщение от Diamante Посмотреть сообщение
надо удалить? удали то, что надо...
Мне нужно удалять уникальные данные, а точнее записи в которых есть уникальные значения. К сожалению, из уникальных есть только ID. Остальные записи иногда, но все же дублируются =/
0
3566 / 2507 / 1174
Регистрация: 14.08.2016
Сообщений: 8,219
10.12.2017, 01:42
кхм, а как "выделяются" те данные, которые надо удалить, если
Цитата Сообщение от sonoramel Посмотреть сообщение
уникальных есть только ID
0
0 / 0 / 1
Регистрация: 01.11.2017
Сообщений: 28
10.12.2017, 01:48  [ТС]
Немного не понял вопрос..
Данные выбираются тогда, когда пользователь на них нажимает, или вы о чем?
0
3566 / 2507 / 1174
Регистрация: 14.08.2016
Сообщений: 8,219
10.12.2017, 01:54
нажимает где? прям в базе?
0
0 / 0 / 1
Регистрация: 01.11.2017
Сообщений: 28
10.12.2017, 01:59  [ТС]
Цитата Сообщение от Diamante Посмотреть сообщение
прям в базе
Нет, не прям в базе

Выводится все в дбгрид, затем, если пользователю нужно выбрать какую-либо запись он просто на нее нажимает и данные переносятся в textbox
C#
1
2
3
textBox1.Text = dataGridView3.SelectedRows[0].Cells[1].Value.ToString();
textBox2.Text = dataGridView3.SelectedRows[0].Cells[2].Value.ToString();
textBox3.Text = dataGridView3.SelectedRows[0].Cells[3].Value.ToString();
0
3566 / 2507 / 1174
Регистрация: 14.08.2016
Сообщений: 8,219
10.12.2017, 02:01
так, юзер нажал, вывелось... дальше?!
0
0 / 0 / 1
Регистрация: 01.11.2017
Сообщений: 28
10.12.2017, 02:07  [ТС]
Цитата Сообщение от Diamante Посмотреть сообщение
дальше
А дальше пользователь уже работает не с таблицей, а с textbox (таблицы две если что склад-заказ). Например запись с добавлением данных в другую таблицу
C#
1
INSERT INTO Change (Status, SubjectName, Quanity, ChangeDate) VALUES ('" + label1.Text + "','" + textBox2.Text + "', '" + textBox3.Text + "', '" + dateTimePicker1.Value.ToString("d/M/yyyy") + "')
0
3566 / 2507 / 1174
Регистрация: 14.08.2016
Сообщений: 8,219
10.12.2017, 02:16
стоило бы начать с выведения данных не в dgv, а в DataTable, с привязкой к dgv
далее работа с DT, а dgv, исключительно для отображения...
0
0 / 0 / 1
Регистрация: 01.11.2017
Сообщений: 28
10.12.2017, 02:18  [ТС]
Мне это поможет удалять записи?
0
3566 / 2507 / 1174
Регистрация: 14.08.2016
Сообщений: 8,219
10.12.2017, 02:24
ну если поймешь смысл, то очень даже...
0
 Аватар для Весельчак-У
35 / 35 / 20
Регистрация: 11.08.2012
Сообщений: 142
10.12.2017, 02:48
sonoramel,
Прошу прощения. Не работал с DataGridView.
А как Вы задаёте источник данных, без использования DataTable?
0
0 / 0 / 1
Регистрация: 01.11.2017
Сообщений: 28
10.12.2017, 03:04  [ТС]
Я использую DataTable, тут например (во всех запросах использую)
C#
1
2
3
4
5
6
7
8
9
10
con.Open();
sc = con.CreateCommand();
sc.CommandType = CommandType.Text;
sc.CommandText = "SELECT * FROM Change";
sc.ExecuteNonQuery();
dt = new DataTable();
sda = new OleDbDataAdapter(sc);
sda.Fill(dt);
dataGridView3.DataSource = dt;
con.Close();
Добавлено через 1 минуту
Ну или так
C#
1
2
3
4
sda = new OleDbDataAdapter("SELECT * FROM Change", con);
dt = new DataTable();
sda.Fill(dt);
dataGridView3.DataSource = dt;
0
 Аватар для Весельчак-У
35 / 35 / 20
Регистрация: 11.08.2012
Сообщений: 142
10.12.2017, 03:16
Если вопрос только в несоответствии типов, то мне кажется, нужно убрать апострофы из текста команды. В апострофы заключаются строковые значения, а поле ID имеет тип Integer.
Не так:
"DELETE FROM Change WHERE ID = '"+ dataGridView3.CurrentRow.Cells["ID"] + "' "

А так:
"DELETE FROM Change WHERE ID = "+ dataGridView3.CurrentRow.Cells["ID"]

А лучше использовать параметры.
C#
1
2
3
4
5
6
7
8
9
//Создаём команду удаления
OleDbCommand deleteCmd = new OleDbCommand();
deleteCmd.CommandText = "DELETE FROM Change WHERE (ID = ?)"; //Текст команды с параметром
deleteCmd.CommandType = CommandType.Text;                    //Тип команды - Текст
deleteCmd.Connection = con;                                  //Подключение
 
deleteCmd.Parameters.Add(new OleDbParameter("ИмяПараметра", OleDbType.Integer));  //Создаём параметр
 
deleteCmd.Parameters["ИмяПараметра"].Value = dataGridView3.CurrentRow.Cells["ID"];  //Задаём значение параметра
Затем эту команду присваиваем свойству DeleteCommand адаптера.

Если не надо одним разом удалять несколько записей, то можно выполнить команду без адаптера:

C#
1
2
3
deleteCmd.Connection.Open();
deleteCmd.ExecuteNonQuery();
deleteCmd.Connection.Close();
0
0 / 0 / 1
Регистрация: 01.11.2017
Сообщений: 28
10.12.2017, 03:55  [ТС]
Сделал в точности как у вас, теперь ошибки не ловятся, но и ничего не удаляется..
Может я где-то что-то упустил?

Добавлено через 3 минуты
А не, я просто
C#
1
deleteCmd.ExecuteNonQuery();
пропустил.

Пишет, что dgv TextBoxCell в Int32 не получится преобразовать
0
 Аватар для Весельчак-У
35 / 35 / 20
Регистрация: 11.08.2012
Сообщений: 142
10.12.2017, 04:06
Что такое TextBoxCell?
0
0 / 0 / 1
Регистрация: 01.11.2017
Сообщений: 28
10.12.2017, 04:12  [ТС]
Цитата Сообщение от Весельчак-У Посмотреть сообщение
Что такое TextBoxCell
Не знаю, класс какой-то
Миниатюры
Как удалить запись по его ID?  
0
 Аватар для Весельчак-У
35 / 35 / 20
Регистрация: 11.08.2012
Сообщений: 142
10.12.2017, 04:14
А если так?
"DELETE FROM Change WHERE ID = "+ dataGridView3.CurrentRow.Cells["ID"].Value
0
0 / 0 / 1
Регистрация: 01.11.2017
Сообщений: 28
10.12.2017, 04:17  [ТС]
Такая же ошибка
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
10.12.2017, 04:17
Помогаю со студенческими работами здесь

Как удалить запись из таблицы?
Здрасте Уважаемые! У меня проблема возникла, нужно удалить определенную запись из таблицы. Т.е. у меня при открытии формы создается...

Как удалить текущую запись
открываю форму добавления новой записи DoCmd.OpenForm stDocName, , , stLinkCriteria DoCmd.GoToRecord , , acNewRec но...

Как удалить запись из комбобокса?
В комбобокс добавляется ненужные мне записи и именами 1 и 2. Мне нужно удалить их программно(через код), как?

Как удалить запись из DataTable?
Как удалить запись из DataTable. Как её тупо удалить. DataRow.Delete(); DataAdapter.Update() DataTable.AcceptChange() А в...

Как удалить запись в таблице?
бд Paradox7, редактирую с помощью DBEdit, вывожу в DBGrid. Подскажите пожалуйста, как удалить запись? С помощью TQuery?


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! */ #include <iostream> #include <stack> #include <cctype>. . .
Камера 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