|
34 / 11 / 0
Регистрация: 22.09.2010
Сообщений: 357
|
||||||
Изменение базы через DataGridView21.03.2011, 16:38. Показов 6331. Ответов 16
Метки нет (Все метки)
Решил написать обычный просмотрщик/редактор *.dbf,*.db файлов, изменение значения ячейки через DataGridView. Но ругается на обработчике событий CellEndEdit, пишет "Для обновления требуется действительный UpdateCommand при передаче коллекции DataRow с измененными строками". Вот код, вроде делал по примеру, что не так, подскажите, пожалуйста.
0
|
||||||
| 21.03.2011, 16:38 | |
|
Ответы с готовыми решениями:
16
Изменение данных в БД через DataGridView Изменение таблицы MS SQL через datagridview Изменение данных БД через DataTable, DataGridView |
|
34 / 11 / 0
Регистрация: 22.09.2010
Сообщений: 357
|
|
| 22.03.2011, 10:20 [ТС] | |
|
Я так понял, указывать запрос на обновление надо, если програмно по заданной команде изменяешь таблицу и на перед знаешь эту таблицу, я правильно думаю? А в моем случае неизвестно что именно будет изменено в таблице и что это будет за таблица, как быть?
0
|
|
|
181 / 107 / 13
Регистрация: 22.03.2010
Сообщений: 456
|
||
| 22.03.2011, 10:51 | ||
|
Поэтому придется динамически создавать запросы на обновление. В любом случае запросы на обновление нужны, так как программа не сможет догадаться что ей делать.
0
|
||
|
34 / 11 / 0
Регистрация: 22.09.2010
Сообщений: 357
|
|
| 22.03.2011, 10:56 [ТС] | |
|
Так вот мне ж интересно, как можно на будущее создать запрос, не зная с какой таблицей придется работать?
0
|
|
|
181 / 107 / 13
Регистрация: 22.03.2010
Сообщений: 456
|
||
| 22.03.2011, 12:35 | ||
|
Как их создать? Вы уже знает после считывания с базы данных структуру таблицы. Этого достаточно чтобы между селект и апдейт создать запросы на обновление.
0
|
||
|
34 / 11 / 0
Регистрация: 22.09.2010
Сообщений: 357
|
|
| 22.03.2011, 13:47 [ТС] | |
|
Ну вот например программа просмотрщик/редактор дбфок - нажимаю на кнопку, выбираю нужный файл и в DataGridView он сразу отображается и тут же можно отредактировать значение нужной ячейки и в файле эти значения должны сохраниться. Я ж наперед не знаю структуру файла, который буду открывать. Как быть?
0
|
|
|
34 / 11 / 0
Регистрация: 22.09.2010
Сообщений: 357
|
|
| 22.03.2011, 17:43 [ТС] | |
|
Кстати, селект к неизвестной таблице написать не проблема, я например так делал
openFileDialog1.ShowDialog(); string strSQL = "Select * from "+openFileDialog1.FileName; string con = @"Provider=Microsoft.Jet.OLEDB.4.0; Data Source=" + Path.GetDirectoryName(openFileDialog1.Fi leName) + "; Extended Properties=DBASE IV"; А вот как теперь предусмотреть изменение произвольного значения в произвольной таблице.
0
|
|
|
|
|
| 22.03.2011, 17:48 | |
|
demonmov, почитй это http://msdn.microsoft.com/ru-r... ilder.aspx
0
|
|
|
34 / 11 / 0
Регистрация: 22.09.2010
Сообщений: 357
|
||||||
| 23.03.2011, 15:07 [ТС] | ||||||
|
Использовал OleDbCommandBuilder и выдало такую ошибку на ad.Update(dSet)
"Динамическое создание SQL для UpdateCommand не поддерживается для SelectCommand, не возвращающей никаких сведений о столбце ключей." А селект у меня такой "Select * from basa" И че делать, даже не знаю. Код всей программы. Тык
Добавлено через 20 часов 30 минут Самое интересное, погуглил, и нашел много тем с ошибкой "Динамическое создание SQL для UpdateCommand не поддерживается для SelectCommand, не возвращающей никаких сведений о столбце ключей." и никто в них так ничего и не подсказал. Может у кого-то есть пример кода где через datagridview вносятся изменения и потом записываются в базу?
0
|
||||||
|
181 / 107 / 13
Регистрация: 22.03.2010
Сообщений: 456
|
||
| 23.03.2011, 15:35 | ||
|
Необходимо в базе данных задать хоть один ключевой столбец. Вообще не понятно, для чего ты мучаешься с проблемой, которую сам же создаешь. Такой способ подключения к базе данных и работу с ней могу оправдать только тем, что база чужая и надо своровать информацию с нее.
0
|
||
|
34 / 11 / 0
Регистрация: 22.09.2010
Сообщений: 357
|
|
| 23.03.2011, 15:57 [ТС] | |
|
Нет же, просто хочу написать редактор\просмотрищик дбф и дб файлов.
0
|
|
|
181 / 107 / 13
Регистрация: 22.03.2010
Сообщений: 456
|
||
| 23.03.2011, 17:16 | ||
|
Если ты не знаешь адрес сервера базы данных и название экземпляра базы данных, если ты не знаешь название конкретной базы данных, логин и пароль к экземпляру базы данных, то ты не сможешь в любом случае подключиться к базе данных. Но если ты все это знаешь, то тебе не трудно посмотреть в базе данных структуру базы данных и ее таблиц. А если ты будешь знать структуру базы данных и таблиц, то тебе не надо просмотрщик. Ты уже знаешь. Можно сделать просмотрщик к известной базе данных, чтобы например, как-то своими визуальными еффектами показывать структуру и прочие атрибуты базы данных. Но, опять же, это будет проще сделать через подключение к известной структуре. На примере ошибки, которую тебе выдает, можешь понять, что неизвестность в структуре базы данных не позволит тебе ее просмотреть. Имеется ввиду столбец с ключами.
1
|
||
|
34 / 11 / 0
Регистрация: 22.09.2010
Сообщений: 357
|
|
| 23.03.2011, 17:57 [ТС] | |
|
На самомделе в моем случае не надо адрес сервера, логины и пароли, т.к. база локальная, представляет из себя один файл дбф или дб. Такие просмотрщики/редакторы на самом деле есть, вот я и хочу свой написать.
0
|
|
|
181 / 107 / 13
Регистрация: 22.03.2010
Сообщений: 456
|
||
| 23.03.2011, 19:02 | ||
|
Я например, с удовольствие тебе бы подсказал как сделать, но в слепую, когда не знаешь структуру базы данных, не знаю как это реализовать. Ведь даже в своем коде ты пишешь название "база". Значит знаешь название. А спрашивается откуда? Если ты собираешься только смотреть есть или нет. Может ты поставил для себя слишком умную задачу? Если бы я смог написать просмотрщик баз данных, которому заранее не надо знать название базы, где файл, логин и пароль. То поверь, Ассанж бы просто отдыхал. Но даже он воспользовался просто проданной ему информацией.
1
|
||
| 23.03.2011, 19:02 | |
|
Помогаю со студенческими работами здесь
17
Как сохранить изменение бд через datagridview Удаление строки из базы данных через DataGridView Обновление MySQL базы через datagridView, нарушение параллелизма Вывод данных в DataGridView из зашифрованной базы Access через TableAdapter Изменение базы при изменении ячейки DataGridView Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Конвертировать закладки 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.
На борту пять. . .
|
Символьное дифференцирование
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. Пошагово создадим проект для загрузки изображения. . .
|