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

Adoquery SQL-запрос

01.05.2012, 10:28. Показов 6510. Ответов 10
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть таблица с группами(Group), и со студентами(Student). И есть dblookupcombobox1, привязанный к таблице с группами. Не получается составить правильно запрос, чтобы в DBGRID отображались при нажатии на кнопку только студенты определенной группы, выбранные в данный момент в dblookupcombobox1.
Пытался по-всякому, на данный момент такой код -
Delphi
1
2
3
4
5
with datamodule2.ADOQuery2 do
begin
sql.Text:='select* from Student Where id_Group = ['+sdblookupcombobox1.keyfield+']';
open;
end;
Выдает что параметр ID_Group(keyfield lookupcombobox'а) не имеет значение по умолчанию.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
01.05.2012, 10:28
Ответы с готовыми решениями:

SQL Запрос в ADOQuery
Проблема заключается в том что простой запрос типа Select * from SKLAD работает. А запрос чуть по крупнее который рабочий...

SQL запрос в ADOQuery
Извиняюсь, если пишу не в ту тему, так как по сути мне нужна помощь по SQL, просто используется он в ADOQuery. Вообщем есть код (фрагмент...

Delphi + ADOQuery+ Запрос SQL
Добрый день уважаемые програмисты! Помогите разобраться с запросом. Есть две таблицы Stb с поляли StbKey, Num, Gr, GrP, Name и Bdg с...

10
5 / 5 / 2
Регистрация: 27.08.2011
Сообщений: 75
01.05.2012, 21:49
Delphi
1
2
3
4
5
with datamodule2.ADOQuery2 do
begin
sql.Text:='select* from Student Where id_Group = ['+IntToStr(Integer(sdblookupcombobox1.keyfield))+']';
open;
end;
0
71 / 71 / 7
Регистрация: 19.07.2011
Сообщений: 357
01.05.2012, 23:05
keyfield - это имя поля, надо keyvalue передавать.
1
0 / 0 / 0
Регистрация: 05.03.2012
Сообщений: 7
02.05.2012, 07:34  [ТС]
Написал так -
Delphi
1
2
3
4
5
with datamodule2.ADOQuery2 do
begin
sql.Text:='select* from Student Where id_Group  = ['+floattostr(sdblookupcombobox1.keyvalue)+']';
open;
end;
Опять параметр из dblookup'а не имеет значения по умолчанию.

Добавлено через 2 часа 38 минут
Все заработало) Сделал так -
Delphi
1
2
3
4
5
with datamodule2.ADOQuery2 do
begin
sql.Text:='select* from Student Where id_Group   LIKE  '''+floattostr(sdblookupcombobox1.keyvalue)+'''';
open;
end;
Теперь другая проблема - можно ли, чтобы dblookupcombobox отображал несколько полей из таблицы (например Фамилию Имя и Отчество)?
0
71 / 71 / 7
Регистрация: 19.07.2011
Сообщений: 357
02.05.2012, 08:05
можно ли, чтобы dblookupcombobox отображал несколько полей из таблицы (например Фамилию Имя и Отчество)?
можно, поскольку dblookupcombobox "ходит" к датасету за своими данными, никто не запрещает сделать искусственное (calc) поле в том справочном датасете, типа
Delphi
1
DataSet['MyFullName']:=DataSet['FirstName']+' '+DataSet['SecondName']+' '+DataSet['LastName'];
, и вместо банальной фамилии (LastName) прописать в качестве ListField - это MyFullName.
0
0 / 0 / 0
Регистрация: 05.03.2012
Сообщений: 7
02.05.2012, 08:45  [ТС]
А куда этот код
Delphi
1
DataSet['MyFullName']:=DataSet['FirstName']+' '+DataSet['SecondName']+' '+DataSet['LastName'];
вписывать? В datasource?
0
71 / 71 / 7
Регистрация: 19.07.2011
Сообщений: 357
02.05.2012, 08:49
у датасета есть проперть-событие OnCalc - туда
0
0 / 0 / 0
Регистрация: 05.03.2012
Сообщений: 7
02.05.2012, 09:03  [ТС]
Я запихал это в oncalcfields в datasource вот такой код получился -

Delphi
1
2
3
4
procedure TDataModule2.ADOTable3CalcFields(DataSet: TDataSet);
begin
DataSet['FullName']:=DataSet['Èìÿ']+' '+DataSet['Ôàìèëèÿ']+' '+DataSet['Îò÷åñòâî'];
end;
Я туда это написал?
0
71 / 71 / 7
Регистрация: 19.07.2011
Сообщений: 357
02.05.2012, 09:13
ессно, а дальше все так же как и в тот раз - в то dblcmb.... ListField = это новое поле MyFullName
только получится по-чуркестански
Василий Петров Иванович
0
0 / 0 / 0
Регистрация: 05.03.2012
Сообщений: 7
02.05.2012, 09:22  [ТС]
В dblookupcombobox:
listsource - datasource где создал событие oncalcfield
listfield - FullName
Пишет что в adotable3 ( с которой связан datasource) не найдено поле FullName
0
71 / 71 / 7
Регистрация: 19.07.2011
Сообщений: 357
02.05.2012, 09:25
на датасете правым кликом вызвать меню списка полей, создать НОВОЕ поле = FullName, тип Calc
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
02.05.2012, 09:25
Помогаю со студенческими работами здесь

ADOQuery + SQL запрос с условием ???
Мне необходимо выбрать из таблицы Person (ID, Name, Secondname, Birthday...) только 3 поля, причем 2 из них объединить: SELECT P.ID,...

SQL запрос для AdoQuery
Каким будет запрос SQL если имеется таблица id_uspev id_uch id_dist ocenka semestr Необходимо при выборе через ComboBox1...

ADOQuery не выполняет запрос SQL
Подскажите, пожалуйста, по такому вопросу, Имеем, Delphi XE, MS SQL 2012 В DataModule1 ADOConnection + ADOQuery + DataSource ...

ADOQuery: ввод переменой с клавиатуры в sql запрос
Доброго времени суток. По задумке пользователь программы должен ввести в Edit процент на который будут изменены все значения в столбце...

ADOQuery - SQL запрос для вывода дубликатов
Привет всем. Подскажите как сформулировать SQL запрос чтобы вывелись все записи с повторяющимися значениями в одном столбце? Конкретнее:...


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

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru