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

Выборка из 3-х таблиц

19.01.2018, 15:40. Показов 1316. Ответов 17
Метки нет (Все метки)

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

У меня 3 таблицы
ПрограммноеОбеспечение, НаименованиеТехники, Связка

Хочу выбрать2 записи из первой таблицы

Delphi
1
2
3
SQL.Clear;
SQL.Add('SELECT ПрограммноеОбеспечение.Наименование,ПрограммноеОбеспечение.Лицензия From ПрограммноеОбеспечение as PO  inner join Связка on PO.Код6=Связка.КодПО');
SQL.Add('inner join НаименованиеТехники as NT on Связка.КодТехники=NT.Код3 where NT.Наименование= "Ноутбук Irbis NB24" ');
Но пишет что пропущен оператор
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
19.01.2018, 15:40
Ответы с готовыми решениями:

Выборка из связанных таблиц
Как выбрать значения из связанных таблиц я знаю. Но в одном из случаев выбирается не всё. Есть таблица пользователей и таблица кабинетов....

Выборка из нескольких таблиц
Необходимо сделать одну таблицу с полями из нескольких таблиц. Таблицы БД: students : budg, fname, id, id_g, otch, surname activity ...

Выборка из двух таблиц
имеется таблица sales(ключевое поле код заказа со счетчиком) и таблица pokypatel, связанные по полю код покупателя, мне нужно сделать cql...

17
5967 / 4543 / 1094
Регистрация: 29.08.2013
Сообщений: 28,157
Записей в блоге: 3
19.01.2018, 16:37
во первых, раз уж сократил, то и используй
Цитата Сообщение от Maratmaratik Посмотреть сообщение
ПрограммноеОбеспечение as PO
во вторых
Цитата Сообщение от Maratmaratik Посмотреть сообщение
NT.Наименование= "Ноутбук Irbis NB24"
вроде как криво

попробуй так
Delphi
1
SQL.Add('inner join НаименованиеТехники as NT on Связка.КодТехники=NT.Код3 where NT.Наименование= '+QuotedStr('Ноутбук Irbis NB24'));
ну и СУБД не написал
0
0 / 0 / 0
Регистрация: 17.01.2018
Сообщений: 13
22.01.2018, 09:26  [ТС]
То же самое- не получилось - ошибка синтаксиса - в задании сказали использовать access
0
5967 / 4543 / 1094
Регистрация: 29.08.2013
Сообщений: 28,157
Записей в блоге: 3
22.01.2018, 09:49
Цитата Сообщение от Maratmaratik Посмотреть сообщение
То же самое- не получилось - ошибка синтаксиса
показывай код, как без него смотреть
0
0 / 0 / 0
Регистрация: 17.01.2018
Сообщений: 13
22.01.2018, 10:39  [ТС]
я немножко подумал головой и - пытаюсь взять данные Наименование из выбранной строки dbgrid записать в переменную и сделать выборку

Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
procedure TForm8.FormShow(Sender: TObject);
 var
i:String;
begin
 
i:=Form1.DBGrid1.DataSource.DataSet.FieldByName('Íàèìåíîâàíèå').AsString;
 
 
with DataModule3.ADOQuery2 do
begin
Close;
SQL.Clear;
SQL.Add('SELECT ПрограммноеОбеспечение.Наименование,ПрограммноеОбеспечение.Лицензия From ПрограммноеОбеспечение as PO inner join (Связка ');
SQL.Add('inner join НаименованиеТехники as NT on Связка.КодТехники=NT.Код3) on PO.Код6=Связка.КодПО where NT.Наименование= i');
  Open;
end;
  end;
0
Айлурофил
 Аватар для Massaraksh7
511 / 445 / 111
Регистрация: 27.05.2017
Сообщений: 2,675
Записей в блоге: 5
22.01.2018, 10:43
Вот это i
Delphi
1
i:=Form1.DBGrid1.DataSource.DataSet.FieldByName('Íàèìåíîâàíèå').AsString;
не имеет никакого отношения вот к этому i
SQL
1
WHERE NT.Наименование= i');
0
0 / 0 / 0
Регистрация: 17.01.2018
Сообщений: 13
22.01.2018, 10:53  [ТС]
после SQL.Clear значение i пропадает?

Добавлено через 2 минуты
Delphi
1
2
3
4
5
6
7
8
with DataModule3.ADOQuery2 do
begin
Close;
SQL.Clear;
SQL.Add('SELECT ПрограммноеОбеспечение.Наименование,ПрограммноеОбеспечение.Лицензия From ПрограммноеОбеспечение as PO inner join (Связка ');
SQL.Add('inner join НаименованиеТехники as NT on Связка.КодТехники=NT.Код3) on PO.Код6=Связка.КодПО where NT.Наименование= [COLOR="Red"]Form1.DBGrid1.DataSource.DataSet.FieldByName('Наименование').AsString[/COLOR]');
Open;
end;
а так можно передать значение выбранной строки ?
0
5967 / 4543 / 1094
Регистрация: 29.08.2013
Сообщений: 28,157
Записей в блоге: 3
22.01.2018, 10:54
Цитата Сообщение от Maratmaratik Посмотреть сообщение
после SQL.Clear значение i пропадает?
нет
у тебя переменная i попадает в кавычки и выводится как текст

Добавлено через 31 секунду
Delphi
1
'where NT.Наименование= '+IntToStr(i)
0
0 / 0 / 0
Регистрация: 17.01.2018
Сообщений: 13
22.01.2018, 10:59  [ТС]
вы сталкивались с такой ошибкой - Параметр ПрограммноеОбеспечение не имеет значение по умолчанию
0
5967 / 4543 / 1094
Регистрация: 29.08.2013
Сообщений: 28,157
Записей в блоге: 3
22.01.2018, 11:04
конечно
у тебя неправильно отформатирован SQL запрос
0
Айлурофил
 Аватар для Massaraksh7
511 / 445 / 111
Регистрация: 27.05.2017
Сообщений: 2,675
Записей в блоге: 5
22.01.2018, 11:10
Цитата Сообщение от qwertehok Посмотреть сообщение
нет
у тебя переменная i попадает в кавычки и выводится как текст
Добавлено через 31 секунду
Delphi
1
'where NT.Наименование= '+IntToStr(i)
i у него - строка. Поэтому - так:
Delphi
1
'where NT.Наименование= '+QuotedStr(i)
0
0 / 0 / 0
Регистрация: 17.01.2018
Сообщений: 13
22.01.2018, 11:17  [ТС]
Связь создал таким образом
Перепроверил SQL запрос - не нахожу ошибки
Миниатюры
Выборка из 3-х таблиц  
0
Айлурофил
 Аватар для Massaraksh7
511 / 445 / 111
Регистрация: 27.05.2017
Сообщений: 2,675
Записей в блоге: 5
22.01.2018, 11:26
А зачем тут вообще какие-то Joinы? Вот так не проще?
Delphi
1
2
3
Sql.Add('SELECT PO.Наименование,PO.Лицензия From');
Sql.Add('ПрограммноеОбеспечение as PO,Связка as SV,НаименованиеТехники as NT');
Sql.Add('where SV.КодТехники=NT.Код3 AND PO.Код6=SV.КодПО AND NT.Наименование='+QuotedStr(i));
Добавлено через 3 минуты

Не по теме:

Я, кстати, Joinами вообще никогда не пользуюсь.

0
0 / 0 / 0
Регистрация: 17.01.2018
Сообщений: 13
22.01.2018, 11:29  [ТС]
Вы не поверите,но ошибка была из-за того, что полсе присвоения имени таблице ПрограммноеОбеспечние as PO, следовало обращаться к именам строк : PO.Наименование, PO.Лицензия
0
5967 / 4543 / 1094
Регистрация: 29.08.2013
Сообщений: 28,157
Записей в блоге: 3
22.01.2018, 11:41
Цитата Сообщение от Massaraksh7 Посмотреть сообщение
Вот так не проще?
не учи плохому.
Вообще все запросы аксессовские сначала надо в аксессе тестить. скобочки какие-нибудь не пропустить

Цитата Сообщение от Massaraksh7 Посмотреть сообщение
Я, кстати, Joinами вообще никогда не пользуюсь.
зря
0
22.01.2018, 11:53

Не по теме:

Цитата Сообщение от qwertehok Посмотреть сообщение
не учи плохому.
Не считаю это плохим.

0
22.01.2018, 11:56

Не по теме:

об этом можно поспорить в ветке по БД)

вот кстати уже был такой холивар

0
22.01.2018, 12:03

Не по теме:

Не люблю я спорить. Пусть каждый выбирает то, что ему ближе.

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
22.01.2018, 12:03
Помогаю со студенческими работами здесь

Выборка из трех таблиц
Доброго времени суток БД Paradox, компонент Query Есть 3 таблицы Table1 (IDt1,Nazvanie,Status_t1) IDt1 - PK ...

Выборка из трёх таблиц DBGrid
Добрый день, не могу понять почему у меня не работает второй JOIN ... Если делаю так то работает, но это объединение двух таблиц, а...

Выборка из нескольких связанных таблиц
Как выбрать значения из связанной таблицы понятно. А как выбрать значения из нескольких связанных таблиц? Есть таблица со списком...

Выборка из нескольких таблиц в Firebird 2.1
Всем Привет! Всех с Новым Годом и Рождеством! Такой вопрос. Из програмы на Делфи работаю с базой Firebird. Есть объект IBQuery. В базе...

Связка двух таблиц, выборка, ADO
Добрый день! Есть 2 таблицы в Access: клиенты и заказы. В Access связь между "клиенты.личный номер" и "заказы.№ клиента"....


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

Или воспользуйтесь поиском по форуму:
18
Ответ Создать тему
Новые блоги и статьи
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. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru