Avatar billede phpbegynder2004 Nybegynder
04. juni 2007 - 17:11 Der er 1 kommentar og
1 løsning

EXPLAIN join - Index problem

Hej Eksperter,

Jeg er igang med at optimere mit website, men er stødt på et problem. Den nedenstående query checker om man har rettigheder til at se et billedealbum. For at kunne se det skal enten:
1. Ens gruppe have rettigheder (undergruppe)
2. Ens individuelle bruger have rettigheder  (brugerid)
3. Albummet skal være fælles (alle='ja')

Hvorfor er "rows" tallet så højt? Hvor skal jeg sætte indexet?

EXPLAIN SELECT DISTINCT year( dato ) AS year
FROM album
LEFT JOIN album_bruger ON album.id = album_bruger.albumid
LEFT JOIN album_undergrupper ON album.id = album_undergrupper.albumid
WHERE
album.alle = 'ja' ||
album_undergrupper.undergruppe = '$_SESSION[undergruppe]' || album_bruger.brugerid = '$_SESSION[id]'
ORDER BY album.id;

Array
(
    [id] => 1
    [select_type] => SIMPLE
    [table] => album
    [type] => ALL
    [possible_keys] =>
    [key] =>
    [key_len] =>
    [ref] =>
    [rows] => 258
    [Extra] => Using temporary; Using filesort
)


Array
(
    [id] => 1
    [select_type] => SIMPLE
    [table] => album_bruger
    [type] => ref
    [possible_keys] => albumid
    [key] => albumid
    [key_len] => 4
    [ref] => sags_dk.album.id
    [rows] => 6
    [Extra] => Distinct
)

Array
(
    [id] => 1
    [select_type] => SIMPLE
    [table] => album_undergrupper
    [type] => ref
    [possible_keys] => albumid
    [key] => albumid
    [key_len] => 4
    [ref] => sags_dk.album.id
    [rows] => 16
    [Extra] => Using where; Distinct
)
Avatar billede 0xffff Nybegynder
04. juni 2007 - 20:50 #1
"3. Albummet skal være fælles (alle='ja')"

His jeg kigger på dit 3 kriterie. Så skal du bruge inner joins istedet for left joins og AND && i din SQL istedet for OR ||.

EXPLAIN SELECT DISTINCT year( dato ) AS year
FROM album
INNER JOIN album_bruger ON album.id = album_bruger.albumid
INNER JOIN album_undergrupper ON album.id = album_undergrupper.albumid
WHERE
album.alle = 'ja' &&
album_undergrupper.undergruppe = '$_SESSION[undergruppe]' && album_bruger.brugerid = '$_SESSION[id]'
ORDER BY album.id;
Avatar billede phpbegynder2004 Nybegynder
17. september 2007 - 02:51 #2
Så udtrækker den pludselig nogle andre data :(
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Computerworld tilbyder specialiserede kurser i database-management

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester