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

DBGrid+Query-> Update?

30.06.2011, 01:39. Показов 4172. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru