пятница, 17 апреля 2020 г.

Для каждого корабля из таблицы Ships указать название ближайшего по времени сражения из таблицы Battles,

Задание: 75 (Serge I: 2009-04-17)
Для каждого корабля из таблицы Ships указать название ближайшего по времени сражения из таблицы Battles, 
в котором корабль мог бы участвовать после спуска на воду. Если год спуска на воду неизвестен, взять последнее по времени сражение. 
Если нет сражения, произошедшего после спуска на воду корабля, вывести NULL вместо названия сражения. 
Замечание. Считать, что корабль может участвовать в сражении, которое произошло в год спуска на воду корабля. 
Вывод: имя корабля, год спуска на воду, название сражения
select shipname,launched,batname
from
(select s.name as shipname,launched,b.name as batname,
row_number() over (partition by s.name order by "date") as num
from ships s,battles b
where to_char("date",'yyyy')>=launched
and launched is not null)
where num = 1
union
(
select name,launched,(select name from battles
where "date" = (select max("date") from battles)) as batname
from ships
where launched is null
)

Все задачи и решения: https://exercises-on-sql.blogspot.com/2017/02/select-sql.html
sql пример,select sql,sql запрос пример,sql запрос,sql использование,написать sql запрос,обучение sql

Комментариев нет:

Отправить комментарий

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

Задание: 120 (mslava: 2004-01-05) Для авиакомпаний, самолеты которой выполнили хотя бы один рейс, вычислить с точностью до двух десятичных...