Форум программистов, компьютерный форум, киберфорум
Delphi: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/15: Рейтинг темы: голосов - 15, средняя оценка - 4.67
0 / 0 / 0
Регистрация: 21.10.2015
Сообщений: 11

Работа с DBGrid и ADOQuery. Создать новую запись, сортировка и удаление

21.10.2015, 17:19. Показов 3139. Ответов 6
Метки нет (Все метки)

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

Доброго времени суток. Прошу сильно не ругаться, что есть еще похожие темы, но у меня проблема, не понимаю как можно: 1) Сделать новую строку в БД заполнив столбцы определенными значениями; 2) Выполнить сортировку в БД, показывая только строки с необходимым значением; 3) Как удалить всю строку зная только значение одного столбца.
Прошу, по возможности подробно описать код, но без фанатизма. Сама в этом новенькая, до этого имела дело только с Ассемблером.
Примерный вид БД прилагаю.
Миниатюры
Работа с DBGrid и ADOQuery. Создать новую запись, сортировка и удаление   Работа с DBGrid и ADOQuery. Создать новую запись, сортировка и удаление  
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
21.10.2015, 17:19
Ответы с готовыми решениями:

Adoquery: вставить новую запись в таблице между существующими
Доброго времени суток! Проблема такая: вставляю новую запись в таблице таким образом Adoquery.Insert; //(Всякие там манипуляции...

Работа с несколькими DBGrid и ADOQuery
Здравствуйте. Делаю программу для работы с базой данных. В базе данных всего одна таблица. В программе есть DataModule, содержащий...

DBGrid создает сам новую запись
Здравствуйте! Пишу программу в C++ builder 6. Столкнулся с проблемой при работе с DBGrid. Добавление записи в таблицу у меня только через...

6
5971 / 4547 / 1094
Регистрация: 29.08.2013
Сообщений: 28,168
Записей в блоге: 3
21.10.2015, 17:26
а вы саму БД создали?
подключились к ней? первичными данными заполнили?
0
0 / 0 / 0
Регистрация: 21.10.2015
Сообщений: 11
21.10.2015, 17:39  [ТС]
Сама БД была создана в MS Access.
Ну а так, это рабочие окна моей БД.
0
5971 / 4547 / 1094
Регистрация: 29.08.2013
Сообщений: 28,168
Записей в блоге: 3
21.10.2015, 17:57
Al_Walker,
как я понимаю у вас Delphi7, у меня версия старше поэтому может что-то отличаться

кидаете на форму Connection для формирования строки подключения к базе
Кидаете Query для выполнения запросов

1) Сделать новую строку в БД заполнив столбцы определенными значениями;
Delphi
1
2
3
4
5
6
Connection.Connected:=False;
Query.Active:=false;
query.sql.text:='insert into [tablename] (тут список полей) VALUES (тут то что вставляете в эти поля) ';
connection.connected:=true;
query.open;
connection:=false;
2) Выполнить сортировку в БД, показывая только строки с необходимым значением;
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
Connection.Connected:=False;
Query.Active:=false;
query.sql.text:='select список_полей from [tablename] WHERE условие ';
connection.connected:=true;
query.active:=true;
 
if query.recordcount>0 then
  while not query.oef do begin
    // тут построчно перебирается полученный массив и можно его вывести в StrinGrid
    query.next;
  end;
connection:=false;
3) Как удалить всю строку зная только значение одного столбца.
Delphi
1
2
3
4
5
6
Connection.Connected:=False;
Query.Active:=false;
query.sql.text:='delete from [tablename] where УСЛОВИЕ ';
connection.connected:=true;
query.open;
connection:=false;
это примерные запросы к БД
1
Эксперт Pascal/Delphi
 Аватар для xxbesoxx
1135 / 616 / 129
Регистрация: 13.02.2009
Сообщений: 3,600
21.10.2015, 18:43
Цитата Сообщение от qwertehok Посмотреть сообщение
3) Как удалить всю строку зная только значение одного столбца.
1) Зачем это ? Connection.Connected:=False; и connection.connected:=true;
2) После INSERT, UPDATE и DELETE надо query.ExecSQL; ели запрос на SELECT тогда query.open;

Добавлено через 5 минут
Delphi
1
2
3
4
5
6
7
8
9
procedure TForm1.Button1Click(Sender: TObject);
begin
 with  ADOQuery1  do
 begin
  sql.Clear;
  sql.text:='delete from [tablename] where УСЛОВИЕ ';
  ExecSQL;
 end;
end;
Добавлено через 8 минут
Цитата Сообщение от qwertehok Посмотреть сообщение
2) Выполнить сортировку в БД, показывая только строки с необходимым значением;

Delphi
1
2
3
4
5
6
7
8
9
10
11
Connection.Connected:=False;
Query.Active:=false;
query.sql.text:='select список_полей from [tablename] WHERE условие ';
connection.connected:=true;
query.active:=true;
if query.recordcount>0 then
 while not query.oef do begin
 // тут построчно перебирается полученный массив и можно его вывести в StrinGrid
 query.next;
 end;
connection:=false;
3) Сортировка и фильтрация это две разные вещи ..! Я не вижу сортировка .!
4) Если не знайте скажу про это
Delphi
1
2
Connection.Connected:=False; // отключается соединение к БД
//и после этого Query.Active:=false; и так он уже на false;
что это ?

Добавлено через 6 минут

Не по теме:

qwertehok, изучайте и потом отвечайте на форуме

0
0 / 0 / 0
Регистрация: 21.10.2015
Сообщений: 11
21.10.2015, 18:47  [ТС]
А! Ещё, не подскажите как правильно написать условие?
Form2.ADOQuery1.SQL.Text:='select Tarif from Info where Label1.Caption'
Так?
И как вывести все в StringGrid?
0
5971 / 4547 / 1094
Регистрация: 29.08.2013
Сообщений: 28,168
Записей в блоге: 3
21.10.2015, 21:09
Цитата Сообщение от Al_Walker Посмотреть сообщение
А! Ещё, не подскажите как правильно написать условие?
Form2.ADOQuery1.SQL.Text:='select Tarif from Info where Label1.Caption'
Delphi
1
Form2.ADOQuery1.SQL.Text:='select Tarif from Info where [B]tarif[/B]=''''+Label1.Caption+'''
не забудьте в условие WHERE вставить имя поля которое нужно найти

Цитата Сообщение от Al_Walker Посмотреть сообщение
И как вывести все в StringGrid?
я же показывал
выполняете запрос, проверяете что есть результат и закручиваете цикл while not query.eof

xxbesoxx,
Цитата Сообщение от xxbesoxx Посмотреть сообщение
Зачем это ? Connection.Connected:=False; и connection.connected:=true;
я так закрываю коннект к БД

Цитата Сообщение от xxbesoxx Посмотреть сообщение
После INSERT, UPDATE и DELETE надо query.ExecSQL
да
Цитата Сообщение от xxbesoxx Посмотреть сообщение
Я не вижу сортировка .!
очень печально
Цитата Сообщение от xxbesoxx Посмотреть сообщение
Если не знайте скажу про это
я ничего не понял
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
21.10.2015, 21:09
Помогаю со студенческими работами здесь

Запись строки в массив, сортировка, удаление и запись в файл
Нужна помощь. Из edit box к нам приходят строки мы их фильтруем. нужно строки записать в массив, отсортировать по последним двум...

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

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

Создать SQL-запрос, добавляющий в таблицу новую запись
1.Создать SQL-запрос, добавляющий в таблицу, содержащую сведения о пассажирском транспорте, новую запись: Гос номер – ВВ148В,...

поставлена задача создать поиск через ADOQuery что бы находило запись по неполной фразе. Помогите пожалуйста, так как в SQL не силен.
Всем доброго дня! Была поставлена задача создать поиск через ADOQuery что бы находило запись по неполной фразе. Помогите пожалуйста, так...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка SDL3 и Box2D из исходников с помощью 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. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru