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

SQL запрос всех таблиц

11.05.2012, 10:42. Показов 2602. Ответов 6
Метки нет (Все метки)

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

Прощу помощи в моей проблеме:
Я пытаюсь вывести 3 таблицы вместе в один DBGird1 и все выводит, но он несколько раз дублируется.
Пример:
1
2
3
1
2
3
и т.д.

Добавлю что количество записей в таблицах неодинакова: в 1-й табл. 2 записи, во 2-й табл. 4 записи, в 3-й табл. 8 записей. Пытаюсь вывести SQL запросом. В идеале хотел бы видеть так:
1 табл. 2 табл. 3 табл
1 1 1
1 1 2
1 2 3
1 2 4
2 3 5
2 3 6
2 4 7
2 4 8

Прошу совета, помощи.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
11.05.2012, 10:42
Ответы с готовыми решениями:

SQL запрос через ADOQuery из нескольких таблиц
Здравствуйте! В общем, проблема такая.. Нужно мне составить отчет, который содержит данные из нескольких таблиц. С этим проблем нет,...

Не работает sql запрос: нужно из 5 таблиц сложить баллы в шестую
"SELECT WQ.Fnam, WQ.im,WQ.team, SUM(word.bal+ss.bal+ps.bal) AS sum_bal FROM WQ, word, ss, ps WHERE word.log = ss.log AND WQ.log=word.log...

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

6
4217 / 3059 / 583
Регистрация: 21.01.2011
Сообщений: 13,203
11.05.2012, 10:54
Покажи, что в каждой таблице и запрос. Иначе только по приведенному результату трудно что-то сказать
0
0 / 0 / 1
Регистрация: 14.02.2011
Сообщений: 153
11.05.2012, 11:09  [ТС]
в первой таблице имя исполнителей и индекс для связи со 2-табл. (тип autoincrement)
во второй название дисков и 2 индекса для связи с 1-табл. и 3-табл. (тип short и autoincrement)
в третьей название песни и индекс для связи со 2-табл. (тип short) + индекс для индивидуальности (тип autoincrement)

запрос SELECT Name1, Name2, Name3 FROM performer, album, song
0
4217 / 3059 / 583
Регистрация: 21.01.2011
Сообщений: 13,203
11.05.2012, 12:25
Цитата Сообщение от Mesken
в первой таблице имя исполнителей и индекс для связи со 2-табл. (тип autoincrement)
во второй название дисков и 2 индекса для связи с 1-табл. и 3-табл. (тип short и autoincrement)
в третьей название песни и индекс для связи со 2-табл. (тип short) + индекс для индивидуальности (тип autoincrement)
В таблице не может быть индекса. Индекс - это отдельный объект БД. Для связи таблиц используются поля.

Цитата Сообщение от Mesken
запрос SELECT Name1, Name2, Name3 FROM performer, album, song
Если в запросе присутствует больше одной таблицы (а это 99.9% случаев), то должны присутствовать условия связи таблиц, иначе ты получаешь декартово произведение строк таблиц. На каждую пару таблиц минимум одно условие связи.
SQL
1
2
3
4
5
6
SELECT *
FROM performer P,
        album A,
        song S
WHERE A.perf_id = P.id
   AND A.song_id = S.id
Тебе еще повезло, что в таблицах всего несколько строк. Если бы строк было хотя бы сотни, то в твоем результирующем запросе (без условий связи) было бы десятки-сотни тысяч строк.

В некоторых СУБД применяется другой синтаксис для условий соединения (через JOIN...ON) - тут надо смотреть конкретно по твоей СУБД
2
0 / 0 / 1
Регистрация: 14.02.2011
Сообщений: 153
11.05.2012, 18:07  [ТС]
Grossmeister, спасибо за помощь.
В таблице не может быть индекса. Индекс - это отдельный объект БД. Для связи таблиц используются поля.
Это я и хотел сказать, просто понятия попутал.

Пожалуйста, помогите мне еще в одном затруднении:
У меня на Form'е есть Edit, набрав там текст и нажав на кнопку должен происходить поиск.
А конкретнее, должен провериться наличия названия исполнителя и показать все его песни.
Мой пример запроса:
SQL
1
2
3
SELECT Name3
FROM song S, album A, performer P
WHERE P.name1 = Edit1->Text AND A.perf_id = P.id AND A.song_id = S.id
Я знаю что ошибка связана с Edit'ом, а остальная часть вроде правильно расписал, т.к. табл. исполнителей и табл. песен не связаны на прямую.
0
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
11.05.2012, 18:31
C++
1
2
3
SELECT Name3
FROM song S, album A, performer P
WHERE P.name1 = '"+Edit1->Text+"' AND A.perf_id = P.id AND A.song_id = S.id
1
0 / 0 / 1
Регистрация: 14.02.2011
Сообщений: 153
11.05.2012, 20:17  [ТС]
Sasha, и вам спасибо
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
11.05.2012, 20:17
Помогаю со студенческими работами здесь

Запрос из всех таблиц
Добрый день. Работаю с маршрутными расписаниями. Сделал на каждый выход отдельную таблицу. Теперь задача получить по запросу время...

Sql запрос объединение таблиц
Есть две таблицы, table_1 и table_2 . В table_1 надо заполнить столбец b на основе данных из table_2. Столбец name общий. Загвоздка в том...

SQL запрос на выборку из 2х таблиц
Здравствуйте! У меня есть 2 таблицы приход и расход товара, нужно сделать выборку по приходу и расходу. По отдельности если делать выходит...

SQL запрос с использованием 2 таблиц
Парни помогите Пожалуйста с запросом.Есть 2 Таблицы 1) Договор , 2)Клиенты нужно сделать так чтобы при выборе Договора появлялась...

SQL запрос использование 2-х таблиц
Парни помогите понять в чем ошибка Мне нужно Найти Из Таблицы Договор по Коду_Договора, Код_Услуги из Таблицы Договор_Услуги и всю...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru