Nano Hash - криптовалюты, майнинг, программирование

Полностью удалить из базы данных MS Access и Gridview Winforms Devexpress?

Я могу временно удалить выбранную строку в gridview, когда я снова открываю ту же форму, она снова отображает все строки, используя этот код

gridview1.DeleteselectedRows(); 

Но мне также нужно полностью удалить из базы данных, поэтому я попробовал этот код, но этот код удалил следующую строку выбранной строки или предыдущую строку выбранной строки из gridview. Что не так в этом коде?

gridview1.DeleteselectedRows();                                                         object temp = gridView1.GetFocusedRowCellValue("InvoiceNumber");

validateDept.InitializeConnection();
OleDbConnection con = new OleDbConnection(validateDept.connetionString);
con.Open();
OleDbCommand delete1 = new OleDbCommand("delete from NewInvoice_1 where InvoiceNumber=" + temp, con);
OleDbCommand delete2 = new OleDbCommand("delete from NewInvoice_2 where InvoiceNumber=" + temp, con);
delete1 .ExecuteNonQuery();
delete2 .ExecuteNonQuery();
con.Close();

  • Вы уверены, что ваш временный объект представляет собой строку с правильным значением InvoiceNumber? 08.02.2014
  • да, он получает правильное значение, но небольшая поправка в коде, который я обновил сейчас 08.02.2014
  • Является ли ваш gridview1.DeleteselectedRows () сначала выполняется, а затем удаляет команды? Если да, он удаляет ту строку, на которой вы хотите сфокусироваться, и перемещает фокус на следующую строку. 08.02.2014
  • да, я сделал это только сейчас, я получил спасибо 08.02.2014
  • Можно ли добавить эту gridview1.DeleteselectedRows(); строчку после закрытия соединения? Это нормально работает? 08.02.2014
  • Думаю, это возможно. Как вы привязываете данные к сетке? с DataTable? Старайтесь ничего не делать, просто удаляйте строки в сетке и сохраняйте DataSet 08.02.2014
  • Я привязываю свойства, а не код. 08.02.2014
  • Я работаю нормально, спасибо. 08.02.2014

Ответы:


1
validateDept.InitializeConnection();
OleDbConnection con = new OleDbConnection(validateDept.connetionString);
con.Open();
OleDbCommand delete1 = new OleDbCommand("delete from NewInvoice_1 where InvoiceNumber=" +        temp, con); 
OleDbCommand delete2 = new OleDbCommand("delete from NewInvoice_2 where InvoiceNumber=" + temp, con);
delete1 .ExecuteNonQuery();
delete2 .ExecuteNonQuery();
con.Close();

не пишите gridview1.DeleteselectedRows(); эту строку сначала, потому что она удаляет выбранную строку из gridview и переходит к следующей строке, тогда база данных удалит следующую строку, поэтому возникает проблема.

11.02.2014
Новые материалы

Кластеризация: более глубокий взгляд
Кластеризация — это метод обучения без учителя, в котором мы пытаемся найти группы в наборе данных на основе некоторых известных или неизвестных свойств, которые могут существовать. Независимо от..

Как написать эффективное резюме
Предложения по дизайну и макету, чтобы представить себя профессионально Вам не позвонили на собеседование после того, как вы несколько раз подали заявку на работу своей мечты? У вас может..

Частный метод Python: улучшение инкапсуляции и безопасности
Введение Python — универсальный и мощный язык программирования, известный своей простотой и удобством использования. Одной из ключевых особенностей, отличающих Python от других языков, является..

Как я автоматизирую тестирование с помощью Jest
Шутка для победы, когда дело касается автоматизации тестирования Одной очень важной частью разработки программного обеспечения является автоматизация тестирования, поскольку она создает..

Работа с векторными символическими архитектурами, часть 4 (искусственный интеллект)
Hyperseed: неконтролируемое обучение с векторными символическими архитектурами (arXiv) Автор: Евгений Осипов , Сачин Кахавала , Диланта Хапутантри , Тимал Кемпития , Дасвин Де Сильва ,..

Понимание расстояния Вассерштейна: мощная метрика в машинном обучении
В обширной области машинного обучения часто возникает необходимость сравнивать и измерять различия между распределениями вероятностей. Традиционные метрики расстояния, такие как евклидово..

Обеспечение масштабируемости LLM: облачный анализ с помощью AWS Fargate и Copilot
В динамичной области искусственного интеллекта все большее распространение получают модели больших языков (LLM). Они жизненно важны для различных приложений, таких как интеллектуальные..