Version 13 (modified by 6 days ago) ( diff ) | ,
---|
Преглед на Детали за достава
Актери:
- Магационер, Доставувач, Менаџер
Чекори во сценариото:
Чекор 1.
- Актерот навигира на Достави копчето од менито при што се прикажува табела со сите идни и минати достави.
- Овој дел е опфатен во предходното сценарио за додавање на Достава.
Чекор 2.
- На посакуваниот ред од табелата клика Детали
- Тука иницијално се вчитуваат основните податоци за доставата и податоците за цена.
SELECT s.shipment_id AS ShipmentId, p.payment_status AS PaymentStatus, CONCAT(e.employee_name, ' ', e.employee_surname) AS EmployeeFullName, CONCAT(vd.make, ' ', vd.model, ' (', v.registration, ')') AS VehicleInfo, TO_CHAR(s.shipment_date, 'DD-MM-YYYY') AS ShipmentDate, COUNT(DISTINCT sl.customer_id) AS NumberOfCustomers, SUM(sl.wine_quantity) AS WineQuantityShipped, SUM(sl.wine_base_price * sl.wine_quantity) AS ShipmentBasePrice, SUM(sl.wine_agreed_price * sl.wine_quantity) AS ShipmentAgreedPrice, COALESCE(ex.shipment_expenses, 0) AS ShipmentExpenses, ROUND( (SUM(sl.wine_agreed_price * sl.wine_quantity) - SUM(sl.wine_base_price * sl.wine_quantity) - COALESCE(ex.shipment_expenses, 0))::NUMERIC , 2) AS ShipmentProfit FROM shipment s JOIN payment p ON s.payment_id = p.payment_id JOIN employee e ON s.employee_id = e.employee_id JOIN vehicle v ON s.vehicle_id = v.vehicle_id join vehicle_details vd on vd.vehicle_details_id = v.vehicle_details_id JOIN shipment_load sl ON s.shipment_id = sl.shipment_id LEFT JOIN (SELECT shipment_id, SUM(amount) AS shipment_expenses FROM shipment_has_expense_of_expense_type GROUP BY shipment_id) ex ON s.shipment_id = ex.shipment_id WHERE s.shipment_id = 1 GROUP BY s.shipment_id, p.payment_status, e.employee_name, e.employee_surname, vd.make, vd.model, v.registration, s.shipment_date, ex.shipment_expenses;
Чекор 3.
- Актерот може да кликне и на копчето Прикажи повеќе детали при што добиваме специфично кое вино било доставено на кој клиент и нивните цени по единица.
select c.customer_name as CustomerName, CONCAT(a.city , ', ', a.street, ', ',a.building_number, ', ', a.postcode) AS CustomerAddress, w.wine_name as WineName, sl.wine_base_price as WineBasePrice, sl.wine_agreed_price as WineAgreedPrice, sl.wine_quantity as WineQuantity from shipment_load sl join customer c on sl.customer_id = c.customer_id join address a on c.address_id = a.address_id join wine w on sl.wine_id = w.wine_id where sl.shipment_id = 5
Attachments (3)
- step1.png (58.7 KB ) - added by 4 weeks ago.
- step2.png (60.5 KB ) - added by 4 weeks ago.
- step3.png (95.2 KB ) - added by 4 weeks ago.
Download all attachments as: .zip
Note:
See TracWiki
for help on using the wiki.