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

Связь между 3-мя таблицами

20.04.2019, 18:22. Показов 1549. Ответов 12

Студворк — интернет-сервис помощи студентам
Добрый день.Очень сильно нужна помощь.
Есть 3 таблицы.Все они связанные между собой(на скриншоте бд).

В delphi на форму добавил 3 DBGrid.
Прописал:
ADOQuery1 в SQL - Select * from LichData
ADOQuery2 в SQL - Select * from Modul
ADOQuery2 в SQL - Select * from Prikaz

Теперь все данные с таблиц видны в своих DBGrid.
Но как теперь мне связать все эти 3 таблицы друг с другом?
Prikaz(номер приказа) с LichData(номер),LichData(код) с Modul(студент).

Пытался связать как было написано в других похожих темах-не получается.

Огромное спасибо заранее!
Миниатюры
Связь между 3-мя таблицами  
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
20.04.2019, 18:22
Ответы с готовыми решениями:

Связь между таблицами
Столкнулся с проблемой,немогу написать запрос,где в одном запросе объеденялись связи между 4 и более таблицами. Призявать по ключевым...

Связь между таблицами
Добрый день. Мне необходимо отобразить данные в DBgrid в Delphi 7, используя ADOQuery, SQL и Access. Таблиц всего десять: Главная...

Связь между таблицами
Имеется две таблицы. OTDEL и Clients. Между ними связь один otdel ко многим clients. Есть база, три звена. Делаю клиент, на нем отобразил...

12
231 / 163 / 54
Регистрация: 26.10.2014
Сообщений: 928
20.04.2019, 19:08
Добавьте на форму ADOQuery, в свойство SQL пропишите следующий код

SQL
1
2
3
4
SELECT * 
FROM prikaz p, lichdata l, modul m
WHERE p.[Номер приказа]=l.[Номер]
    AND p.[Код]=m.[Студент]
0
0 / 0 / 0
Регистрация: 13.12.2018
Сообщений: 11
20.04.2019, 19:18  [ТС]
То есть добавить четвёртый Adoquery к тем трём?
Миниатюры
Связь между 3-мя таблицами  
0
0 / 0 / 0
Регистрация: 13.12.2018
Сообщений: 11
20.04.2019, 19:21  [ТС]
Ошибку выдаёт.
Миниатюры
Связь между 3-мя таблицами  
0
231 / 163 / 54
Регистрация: 26.10.2014
Сообщений: 928
20.04.2019, 20:23
drozdov9191, а вот такой
MySQL
1
2
3
SELECT * 
FROM prikaz p, lichdata l, modul m
WHERE p.[Номер приказа]=l.[Номер]
Добавлено через 2 минуты
Цитата Сообщение от drozdov9191 Посмотреть сообщение
То есть добавить четвёртый Adoquery к тем трём?
сколько у вас dbgrid - столько datasource - столько же adoquery
я бы на вашем месте не использовал русские имена полей таблицы
0
0 / 0 / 0
Регистрация: 13.12.2018
Сообщений: 11
20.04.2019, 20:47  [ТС]
Вот вверху каждая Adoquery и DataSource относится к своей DBGrid.
SQL
1
2
3
SELECT * 
FROM prikaz p, lichdata l, modul m
WHERE p.[Номер приказа]=l.[Номер]
Этот код вставил.он принял без ошибок,но связь все равно не происходит.Сразу во всех таблицах отображаются все данные,которые введены(без связи).
Миниатюры
Связь между 3-мя таблицами  
0
231 / 163 / 54
Регистрация: 26.10.2014
Сообщений: 928
20.04.2019, 21:02
ADOQuery - это штука которая выполняет запрос
DBGrid - это штука которая отображает данные из таблиц, полученные этим запросом
DataSource - это штука которая связывает предыдущие две штуки

То есть вам нужно прицепить ADOQuery4 к какому нибудь DBGrid, только в таком случае вы увидите изменения, там будут данные из трех таблиц
Но помните, что нам еще надо с запросом разобраться, в данный момент он связывает только две таблицы, третья просто рядом
0
0 / 0 / 0
Регистрация: 13.12.2018
Сообщений: 11
20.04.2019, 21:12  [ТС]
То,что вы выше написали, я это все понимаю.Результат AdoQuery4 (с SQL запросом) идёт в в DBgrid с модулем.Но Связи все равно нет.Создавая нового пользователя,у него в модуле отображаются данные всех пользователей.
0
231 / 163 / 54
Регистрация: 26.10.2014
Сообщений: 928
20.04.2019, 22:48
Цитата Сообщение от mac1eod Посмотреть сообщение
Но помните, что нам еще надо с запросом разобраться, в данный момент он связывает только две таблицы, третья просто рядом
правильный запрос будет иметь вот такой вид
SQL
1
2
3
4
SELECT * 
FROM prikaz p, lichdata l, modul m
WHERE p.[Номер приказа]=l.[Номер]
    AND p.[Код]=m.[Студент]
осталось понять почему поле код не воспринимается

Добавлено через 5 минут
потому что я ошибся, а вы не заметили
SQL
1
2
3
4
SELECT * 
FROM prikaz p, lichdata l, modul m
WHERE p.[Номер приказа]=l.[Номер]
    AND l.[Код]=m.[Студент]
0
0 / 0 / 0
Регистрация: 13.12.2018
Сообщений: 11
21.04.2019, 10:52  [ТС]
Я вообще ничего не понимаю.Опять связи нет...Создавая приказ и добавляю в него список студентов,а к выбранному студенту добавляю предметы,ничего опять.Связи нет....

Вот как делаю:
1. Приказ(ADOQuery3, в SQL пишу - Select * from Prikaz),его подключаю к DBgrid3.
2. Список студентов(ADOQuery1, в SQL пишу - Select * from LichData).,его подключаю к DBgrid1.
3. Модуль(ADOQuery2, в SQL пишу ваш код -
SQL
1
2
3
4
SELECT * 
FROM prikaz p, lichdata l, modul m
WHERE p.[Номер приказа]=l.[Номер]
    AND l.[Код]=m.[Студент]
,его подключаю к DBgrid2.

В итоге ничего не выходит....может я что-то не то делаю?
Миниатюры
Связь между 3-мя таблицами  
0
0 / 0 / 0
Регистрация: 13.12.2018
Сообщений: 11
21.04.2019, 11:22  [ТС]
То есть если смотреть по колонкам то данные из тех 2-ух добавляются в 3-тью (обьединяются),но связи нет(если создаю новый приказ и создаю нового студента),потом создаю новый приказ,то в нем все равно отображаются все студенты(и из другого приказа).
0
231 / 163 / 54
Регистрация: 26.10.2014
Сообщений: 928
21.04.2019, 12:18
drozdov9191, выложите проект, что то я уже запутался
0
0 / 0 / 0
Регистрация: 13.12.2018
Сообщений: 11
21.04.2019, 12:50  [ТС]
Да,конечно.В личные сообщения вам скинул.
 Комментарий модератора 
drozdov9191, это прямое нарушение п. 4.6 Правил форума:
Обсуждение вопросов - только в теме на форуме. Приглашения к обсуждению еще где-либо (в том числе и с помощью системы личных сообщений) запрещены, за исключением коммерческих разделов.
Официальное предупреждение!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
21.04.2019, 12:50
Помогаю со студенческими работами здесь

Связь между таблицами
Здравствуйте, вообщем в приложении есть доставка топлива, определенное количество, нужно что бы при продаже на другой вкладке убавлялось...

Связь между таблицами в БД
Добрый день, я делаю базу данных продажи билетов, и мне нужно связать 2 таблицы, честно скажу в связывании я не разобрался не капли не могу...

Связь между таблицами
Здравствуйте. Я разрабатываю базу данных, У меня имеется две таблицы, связанные между собой. Связь один-ко-многим. 1 таблица -...

Связь между таблицами
добрый день всем. у меня вот вопрос 1 как связать две таблицы проста так я их связал но мне надо когда в первый таблице ты выбираешь город...

Связь между таблицами
пытаюсь сделать связь такого плана: при нажатии в бдлукаплистбокс (привязному к основной таблице) по ключевому полю, эдиты заполняются...


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

Или воспользуйтесь поиском по форуму:
13
Ответ Создать тему
Новые блоги и статьи
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек SDL3 и Box2D из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия SDL 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual. . .
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