wiki:AdvancedReports

Напредни извештаи од базата (SQL и складирани процедури)

Извештај за сите решени случаеви од минатата година кој што ги водат полициските станици во секорот за внатрешни работи во Скопје. Дополнително за секој решен случај да се пресмета бројот на дадени изјави

select cc.c_id as c_id,cc.c_name as c_name,
cc.opening_date as opening_date,sc.date_of_closing as date_of_closing,
sc.final_document as final_document,
(select count(*) from statements  where c_id=cc.c_id) as broj_na_izjavi
from
sector_of_interal_affairs sia
join police_station ps on sia.s_id=ps.s_id
join crime_case cc on ps.p_id=cc.p_id
join solved_case sc on cc.c_id=sc.c_id
where
sia.city ~ '(Skopje|Скопје)'

Извештај за секоја полициска станица, колку вработени полицајци има, колку од нив се вработени во последните 2 години и колку од нив се со македонска националност

select ps.p_id, ps.p_address,
        count(po.pe_id) as vkupno_policajci,
        (select count(*)
                        from people p
                        join policeman pol on p.pe_id=pol.pe_id
                        where
                        p.nationality='Македонец' and pol.p_id=ps.p_id) as Makedonci_nachalnici_i_policajci,
        (select count(*) from policeman pol
        where p_date_of_employment between now()-interval '2 years' and now()
        and pol.p_id=ps.p_id ) as Vraboteni_vo_interval_2_god
from police_station ps
join policeman po on po.p_id = ps.p_id
group by ps.p_id;

Извештај за секоја сектор за внатрешни работи, колку вработени има во сите полициски станици секторот кои што имаат ранг поголем од 2 и се помлади од 30 години

select sia.s_id as sector_id, sia.city as sector_city,
ps.p_id as police_station_id, ps.p_address as police_station_address,
(select count(*) from 
 people pe 
 join policeman pl on pe.pe_id=pl.pe_id
 where rank>2 and pl.p_id=ps.p_id) as broj_na_vraboteni_so_rang_pogolem_od_2,
 (select count(*) from 
    crime_case cc
    join solved_case  sc on cc.c_id=sc.c_id
    where
    cc.p_id=ps.p_id
 ) as broj_na_resheni_slucai
from sector_of_interal_affairs sia
join police_station ps on sia.s_id=ps.s_id
join policeman p on ps.p_id=p.p_id

Извештај за секоја полициска станица, колку случаи биле отворени со тип на криминал ‘Семејно насилство’ и колку жртви биле жени од ромско потекло

select ps.p_id, ps.p_address, 
        (
        select count(cs.c_id) 
        from police_station ps
        join crime_case cs on cs.p_id = ps.p_id
        join statements st on st.c_id = cs.c_id
        join victim vic on vic.pe_id = st.victim_pe_id
        join people pe on pe.pe_id = vic.pe_id
        join case_belongs_to_type_of_crime cbtt on cbtt.c_id = cs.c_id
        join type_of_crime toc on toc.t_id = cbtt.t_id
        where pe.gender = 'Ж' and toc.t_name = 'Семејно насилство' 
        and pe.nationality = 'Ромка'
        ) as vk_sluchaevi_zheni_zhrtvi
from police_station ps
group by ps.p_id;

Извештај за секоја полициска станица кој полицаец има земено најмногу изјави во последната година

with stanici_policajci_izjavi
         as (select ps.p_id, ps.p_address, pm.pe_id, pm.badge_no, count(s.c_id) br_izjavi
             from police_station ps
                      left join policeman pm on ps.p_id = pm.p_id
                      left join statements s on pm.pe_id = s.pe_id
             group by ps.p_id, ps.p_address, pm.pe_id, pm.badge_no),
     stanici_max_izjavi
         as (select psi.p_id, psi.p_address, max(psi.br_izjavi) max_izjavi
             from stanici_policajci_izjavi psi
             group by psi.p_id, psi.p_address)

select psi.p_id, psi.p_address, psi.pe_id, psi.badge_no, psi.br_izjavi
from stanici_policajci_izjavi psi
         join stanici_max_izjavi smi
              on (psi.p_id, psi.p_address, psi.br_izjavi) = (smi.p_id, smi.p_address, smi.max_izjavi)

Извештај за секој тип на криминал која полициска станица има отворено најмногу случаеви со тој тип на криминал

SELECT 
    toc.t_id AS type_id,
    toc.t_name AS type_name,
    ps.p_id AS station_id,
    ps.p_address ,
    COUNT(cs.c_id) AS case_count
FROM 
    type_of_crime toc
JOIN case_belongs_to_type_of_crime cbtt ON toc.t_id = cbtt.t_id
JOIN crime_case cs ON cbtt.c_id = cs.c_id
JOIN police_station ps ON cs.p_id = ps.p_id
GROUP BY 
    toc.t_id, toc.t_name, ps.p_id, ps.p_address 
HAVING 
    COUNT(cs.c_id) = (
        SELECT 
            MAX(case_count)
        FROM (
            SELECT 
                toc_sub.t_id AS type_id,
                COUNT(cs_sub.c_id) AS case_count
            FROM 
                type_of_crime toc_sub
            JOIN 
                case_belongs_to_type_of_crime cbtt_sub ON toc_sub.t_id = cbtt_sub.t_id
            JOIN 
                crime_case cs_sub ON cbtt_sub.c_id = cs_sub.c_id
            GROUP BY 
                toc_sub.t_id
        ) max_cases
        WHERE max_cases.type_id = toc.t_id
    )
ORDER BY 
    toc.t_id, case_count DESC;
Last modified 10 months ago Last modified on 01/15/24 22:16:34
Note: See TracWiki for help on using the wiki.