Diskuze: Vyhledání dle počtu záznamů z jiné tabulky
V předchozím kvízu, Online test znalostí SQL a databází, jsme si ověřili nabyté zkušenosti z kurzu.
Tvůrce
Zobrazeno 4 zpráv z 4.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí SQL a databází, jsme si ověřili nabyté zkušenosti z kurzu.
Jen podotýkám, že to HAVING COUNT(resource.id) = 3 mi má ověřit, že se všechny tři záznamy z tabulky resource shodují a že uživatel dané resources má. Použil jsem to snad poprvý v životě, takže si nejsem jistý, jestli to funguje tak, jak si myslím
Principielně to máš správně. Je třeba ještě ale použít distinct nad
tím sloupcem, kde počítáš count. Když ho nepoužiješ a uživatel bude
mít více stejných resources (např. 2krát "add"), tak ho to zahrne do
výsledku.
Navíc bys měl mít v having podmínce ">=" namísto "=", protože říkáš
že chceš i ty, který by jich měli víc.
Když vyjmenováváš hodnoty v klauzuli IN, stačí tam hodnotu mít jen jednou
("User").
Já bych to napsal takhle:
select user.id, user.name, count(distinct resource_name) from user
join user_resource on user.id = user_resource.user_id
join resource on user_resource.resource_id = resource.id
where resource.section = 'User'
and resource.name in ('add', 'edit', 'delete')
group by user.id, user.name
having count(distinct resource_name) >= 3
Díky za radu já prvně si
nebyl jistý, jestli to vůbec jedním dotazem půjde vyřešit, nakonec se tedy
zdá, že to jde.
Já ty resources dostanu jednotlivě v poli, takže jsem to raději řešil
přes IN(), kam se postupně nacpou všechny ty hodnoty. Takže když některé
ty resources budou mít stejnou sekci nebo název, vypíše se tam vícekrát.
Tím, doufám, pořeším možnost, že kdyby byly např.:
// sekce : název
User:add
User:edit
Article:add
Article:edit
tak pokud bude uživatel mít User:add, ale už ne Article:add, aby mi to toho uživatele nebralo včetně.
Zobrazeno 4 zpráv z 4.