Форум программистов, компьютерный форум, киберфорум
C++ Builder: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.64/22: Рейтинг темы: голосов - 22, средняя оценка - 4.64
0 / 0 / 0
Регистрация: 22.06.2011
Сообщений: 13

DBGrid+Query-> Update?

30.06.2011, 01:39. Показов 4199. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Как зделать Update table при DBGrid edit, если у DBGrid->DataSource->TQuery?
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
30.06.2011, 01:39
Ответы с готовыми решениями:

C++ Builder Query - UPDATE для двух таблиц
Здравствуйте. Помогите сформировать запрос: Есть 3 таблицы (тема - сессия студентов): 1. Группа (ИД, название) 2. Студент (ИД, ФИО,...

Сортировка DBGrid при помощи Query
Всем доброго времени суток. Необходимо отсортировать столбец, создаю таблицу через Table. В интернете много примеров сортировки, но все...

DBGrid, Delete/Update, Table is read only
У меня DbGrid (Datasource->Query). Эсли делать Delete через DBNavigator то ошибка "Table is read only." (хотя все Readonly = false) и...

2
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
30.06.2011, 09:19
Лучший ответ Сообщение было отмечено renathy как решение

Решение

Цитата Сообщение от renathy Посмотреть сообщение
Как зделать Update table при DBGrid edit
C++
1
2
3
Close()
Open()
или Requery()
Добавлено через 3 минуты
C++
1
Refresh()
0
1497 / 1238 / 245
Регистрация: 04.04.2011
Сообщений: 4,363
30.06.2011, 10:24
Вы, вероятно хотели сказать не "Update", а "Edit".
Править датасет (но не грид !) можно в том случае, если компонент-"обертка" (в Вашем случае TQuery) позволяет это сделать, т.е. датасет редактируемый - CanModify = true. Однако это бывает далеко не всегда. Точнее лишь в некоторых случаях, когда запрос не содержит
1) Вычисляемых полей
2) Обращений более чем к одной таблице (Join)
3) Группирующих функций (Sum, Count, Group By...)
4) Подзапросов (Select A, Select B from..., C...) и вложенных запросов (Select ... from (Select ... ))
В общем случае, если Ваш запрос отличается от шаблона
Select <список полей тпблицы> from MyTable where <Простое условие>
то скорее всего датасет не является редактируемым, а значит даже если Вы попытаетесь вносить правки в сетку (а это при определенных телодвижениях нетрудно осуществить, тем более что грид не сильно-то и возражает , то при попытке постинга получите AV с соотв. текстом

Однако для любителей "сеточных" правок борланды сделали поблажку - написали аппендикс TUpdateSQL, посредством которого (и при известных руко- и мозгозатратах конечно) таки можно вносить правки в любой датасет, фактически "обманывая" TQuery.
Подобных хитроватый метод, конечно, имеет право на жизнь, но все же ИМХО стОит подумать о том, чтобы уйти от технологии внесения правок через сетку (любимая бухгалтерами и айти-менеджерами эксельная манера работы с таблицами) в сторону нормального клиент-серверного редактирования через модальные формы.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
30.06.2011, 10:24
Помогаю со студенческими работами здесь

Считать из поля Edit вписанное значение и через запрос (query) вывести строку с этим значением значением в dbgrid.
считать из поля Edit вписанное значение и через запрос (query) вывести строку с этим значением значением в dbgrid. Добавил query,...

UPDATE Query failed
Доброго времени суток. Беру введенные данные пользователем и обновляю их в таблице но пишет Query failed, в чем ошибка? if...

Update query Php Mysql
Подскажите, где ошибка, не хочет изменять изменения, вносит их в таблицу &lt;form action=&quot;&quot; method=&quot;post&quot;&gt; ...

UPDATE. Query was empty. В чем ...?
# Записываем в БД новый хеш авторизации и IP $query=mysql_query(&quot;UPDATE user SET hash='&quot;.$hash.&quot;'&quot;.$insip.&quot; WHERE...

Lazarus + Firebird: No update query specified and failed to generate one
Привет форумчанам! Я, в рамках дипломной работы делаю БД используя лазарус и firibird (как сервер бд..) столкнулся с проблемой: ...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
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&amp;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. На борту пять. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru