Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 2.00/1: Рейтинг темы: голосов - 1, средняя оценка - 2.00
0 / 0 / 0
Регистрация: 06.03.2017
Сообщений: 5

SQL Запрос SELECT отношение многие ко многим

29.10.2024, 17:30. Показов 513. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день!
Подскажите пожалуйста следующее: нужно составить SQL запрос результатом которого будет список фамилий водителей, за которыми закреплено два или более автомобиля марки Toyota. За одним водителем может быть закреплено более одного автомобиля, а у одного автомобиля может быть несколько водителей. Спасибо!

1. Таблица driver, которая содержит информацию о водителях таксопарка. Она содержит поля:
id - уникальный идентификатор водителя;
first_name - имя водителя;
last_name - фамилия водителя;
driving_experience - стаж вождения;
birth_date - дата рождения водителя.

2. Таблица car, которая содержит информацию об автомобилях таксопарка. Она содержит поля:
id - уникальный идентификатор автомобиля;
brand - марка автомобиля;
manufacturing_year - год выпуска автомобиля;
mileage - пробег автомобиля.

3. Таблица car_driver, которая содержит информацию о том, какой автомобиль закреплен за каким водителем. Она содержит поля:
id - уникальный идентификатор записи;
car_id - идентификатор автомобиля;
driver_id - идентификатор водителя, за которым закреплен автомобиль.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
29.10.2024, 17:30
Ответы с готовыми решениями:

SQL и Связь многие ко многим
Здравствуйте гуру:Прошу помочь в написании запроса к следующим данным: есть 3-и таблицы связанные между собой ----------- 1)...

Запрос на выборку многие к многим
Здравствуйте,помогите написать запрос на выборку есть БД из 3 х таблиц вот она:http://fotohosting.org/share.php?id=DA40_4EE912D3 ...

SQL запрос многие ко многим
Добрый день! Есть таблица студентов (students) и курсов, которые они посещают (courses). Нужно выбрать студентов, которые посещают не...

6
 Аватар для Аватар
5393 / 1465 / 513
Регистрация: 31.05.2012
Сообщений: 5,153
29.10.2024, 17:37
SQL
1
2
3
4
5
6
SELECT d.last_name
  FROM driver d
    JOIN car_driver cd ON cd.driver_id=d.id 
    JOIN car c ON c.id=cd.car_id AND c.brand='Toyota'
  GROUP BY d.id,d.last_name
  HAVING COUNT(*)>1

зы от такого изучения результат даже не ноль, а отрицательный ))
0
932 / 365 / 43
Регистрация: 10.05.2021
Сообщений: 1,564
Записей в блоге: 10
29.10.2024, 17:49
Evg1988, здравствуйте!
Очень похоже на задачу при устройстве на работу. Свои наработки имеются? Что не получается?
Запрос получается несложный.

UPD:
Раз Аватар уже показал, то и своё покажу:
Код
T-SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
With
    A As
    (
        Select  id
        From    car
        Where   brand = 'Toyota'
    ),
    B As
    (
        Select      B.driver_id
        From        A
        Inner Join  car_driver  As B On B.car_id = A.id
        Group By    B.driver_id
        Having      Count(*) > 1
    )
Select      D.last_name
From        B
Inner Join  driver As D On D.id = B.driver_id
0
 Аватар для Аватар
5393 / 1465 / 513
Регистрация: 31.05.2012
Сообщений: 5,153
29.10.2024, 18:59
не, ну при наличии подзапросов, да если еще с глубиной вложенности не тривиальной смысл использования cte понятен и приветствуется. а в данном случае зачем вместо одного достаточно простого запроса три запроса? писк моды что-ли? почти уверен что и менее эффективный писк )
0
0 / 0 / 0
Регистрация: 06.03.2017
Сообщений: 5
29.10.2024, 19:40  [ТС]
Спасибо большое!
Вы правы это один из вопросов по тесту по Java.
Я Java знаю неплохо а вот SQL подзабыл.
0
 Аватар для Andrey-MSK
3342 / 2229 / 387
Регистрация: 14.08.2018
Сообщений: 7,521
Записей в блоге: 4
30.10.2024, 08:21
Цитата Сообщение от Evg1988 Посмотреть сообщение
Спасибо большое!
Для спасибо кнопки есть под сообщениями...
1
Модератор
 Аватар для D1973
9921 / 6457 / 2457
Регистрация: 21.01.2014
Сообщений: 27,401
Записей в блоге: 3
30.10.2024, 08:55
Цитата Сообщение от Andrey-MSK Посмотреть сообщение
Для спасибо кнопки есть под сообщениями...
А ТС и про это "подзабыл" за столько лет на форуме...
2
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
30.10.2024, 08:55
Помогаю со студенческими работами здесь

SQL запрос к таблицам многие-ко-многим с ограничениями
Обращаюсь за помощью с формированием SQL запроса. Суть следующая: Есть 2 таблицы Таблица 1 - Задачи: Data - дата создания...

Отношение многие ко многим
Здравствуйте! Есть задача Есть две сущности АВТОРЫ и КНИГИ, связь М-М (многие к многим). Создайте структуру таблиц для этих сущностей и...

SQL-запрос при связи "многие-ко-многим"
Здравствуйте! При написании запроса возник вопрос - как его организовать, что бы в результате не было повторений. Есть 3 таблицы: ...

Запрос многие ко многим
Добрый день. Такой вопрос: Нужно вывести записи в следующем формате: teacher | disciplines teachername | discipline1, discipline2,...

Запрос Многие ко Многим
Приветствую. Помогите написать запрос, если такой, вообще, возможен. Есть 3 таблицы. Реализуется классическое отношение многие-ко-многим....


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Ритм жизни
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