Руководство по созданию эффективных запросов



Download 17,08 Mb.
Pdf ko'rish
bet162/210
Sana25.06.2022
Hajmi17,08 Mb.
#704548
TuriРуководство
1   ...   158   159   160   161   162   163   164   165   ...   210
Bog'liq
OptimizZaprvPostgreSQL

Листинг 11.21 

Функция, возвращающая сложный объект
с вложенной структурой
CREATE OR REPLACE FUNCTION booking_leg_select (p_booking_leg_id int)
RETURNS SETOF booking_leg_record
AS $body$
BEGIN
RETURN QUERY
SELECT bl.booking_leg_id,
leg_num,
bl.booking_id,
( SELECT row(
flight_id,
flight_no,
departure_airport,
da.airport_name,
arrival_airport,
aa.airport_name,
scheduled_departure,
scheduled_arrival
)::flight_record
FROM flight f
JOIN airport da ON da.airport_code = departure_airport
JOIN airport aa ON aa.airport_code = arrival_airport
WHERE flight_id = bl.flight_id
),
( SELECT array_agg (row(
pass_id,
bp.booking_leg_id,
flight_no,
departure_airport ,
arrival_airport,
last_name,
first_name,
seat,
boarding_time
)::boarding_pass_record)
FROM flight f1
JOIN boarding_pass bp ON f1.flight_id = bl.flight_id
AND bp.booking_leg_id = bl.booking_leg_id
JOIN passenger p ON p.passenger_id = bp.passenger_id
)
FROM booking_leg bl
WHERE bl.booking_leg_id = p_booking_leg_id;
END;
$body$
LANGUAGE plpgsql;


212

Функции
Бросается в глаза, что по сути тот же самый запрос мы уже использовали 
в функции 
boarding_pass_flight
. Отличия заключаются в следующем:
 

не требуется соединение с таблицей 
booking_leg
, так как она уже была 
выбрана во внешнем запросе. Информация из таблицы 
flight
нам 
нужна, но мы можем использовать 
flight_id
из выбранного сегмента 
бронирования. Таким образом, получается декартово произведение 
с одной строкой из таблицы 
flight
;
 

точно так же для посадочного талона нет соединения с таблицей 
book-
ing_leg
; мы просто используем имеющийся 
booking_leg_id
.
Наконец, мы используем встроенную функцию 
array_agg
для создания еди-
ного 
массива
записей
, который ожидается в качестве последнего элемента 
booking_leg_record
.

Download 17,08 Mb.

Do'stlaringiz bilan baham:
1   ...   158   159   160   161   162   163   164   165   ...   210




Ma'lumotlar bazasi mualliflik huquqi bilan himoyalangan ©hozir.org 2024
ma'muriyatiga murojaat qiling

kiriting | ro'yxatdan o'tish
    Bosh sahifa
юртда тантана
Боғда битган
Бугун юртда
Эшитганлар жилманглар
Эшитмадим деманглар
битган бодомлар
Yangiariq tumani
qitish marakazi
Raqamli texnologiyalar
ilishida muhokamadan
tasdiqqa tavsiya
tavsiya etilgan
iqtisodiyot kafedrasi
steiermarkischen landesregierung
asarlaringizni yuboring
o'zingizning asarlaringizni
Iltimos faqat
faqat o'zingizning
steierm rkischen
landesregierung fachabteilung
rkischen landesregierung
hamshira loyihasi
loyihasi mavsum
faolyatining oqibatlari
asosiy adabiyotlar
fakulteti ahborot
ahborot havfsizligi
havfsizligi kafedrasi
fanidan bo’yicha
fakulteti iqtisodiyot
boshqaruv fakulteti
chiqarishda boshqaruv
ishlab chiqarishda
iqtisodiyot fakultet
multiservis tarmoqlari
fanidan asosiy
Uzbek fanidan
mavzulari potok
asosidagi multiservis
'aliyyil a'ziym
billahil 'aliyyil
illaa billahil
quvvata illaa
falah' deganida
Kompyuter savodxonligi
bo’yicha mustaqil
'alal falah'
Hayya 'alal
'alas soloh
Hayya 'alas
mavsum boyicha


yuklab olish