Avatar billede palito Nybegynder
26. oktober 2007 - 17:22 Der er 4 kommentarer

Hent informationer om artikel og teksten i en anden tabel

Jeg har en funktion der er vist forneden, hvor jeg vil hente noget indhold om en en artikel og derefter hente selve teksten til artiklen i en anden tabel. Hvordan gør man det smartest? Jeg vil ende ud med, at returnere et array med al indholdet.

Jeg har desuden nogle problemer med hvordan "redirect"-funktionen skal fungere :)

Er der nogle der har nogle forslag?

function hent($titel) {
    $query = mysql_query("SELECT `titel`, `tekstid`, `dato`, `redirect` FROM `artikler` WHERE `title` = '{$titel}' LIMIT 1");
    if(mysql_num_rows($query) == 1) {
        $foo = mysql_fetch_object($query);
        if(is_null($foo->redirect)) {
            $query2 = mysql_query("SELECT `tekst` FROM `artikelTekst` WHERE `id` = '{$foo->tekstid}' LIMIT 1");
            if($database->numRows($query2) == 1) {
                return mysql_fetch_assoc($query2);
            }
        }
        else
        {
            // redirect
        }
    }
}
Avatar billede palito Nybegynder
26. oktober 2007 - 17:50 #1
kan dette skrives smartere?

function hent($titel) {
    $query = mysql_query("SELECT `titel`, `tekstid`, `dato`, `redirect` FROM `artikler` WHERE `title` = '{$titel}' LIMIT 1");
    if(mysql_num_rows($query) == 1) {
        $foo = mysql_fetch_object($query);
        $query2 = mysql_query("SELECT `tekst` FROM `artikelTekst` WHERE `id` = '{$foo->tekstid}' LIMIT 1");
        if($database->numRows($query2) == 1) {
            $row = $database->fetchObject( $query2 );
            return array(
                'titel'    => $foo->titel,
                'tekst'    => $row->tekst
            );
        }
    }
}
Avatar billede jakobdo Ekspert
26. oktober 2007 - 21:40 #2
Sådan måske:

function hent($titel)
{
    $query = mysql_query("SELECT a.titel, as.tekst FROM artikler a INNER JOIN artikelTekst at ON a.tekstid = at.id WHERE title = '{$titel}' LIMIT 1");
    if(mysql_num_rows($query) == 1) {
        $row = mysql_fetch_object($query);
        return array(
            'titel'    => $row->titel,
            'tekst'    => $row->tekst
        );
    }
}
Avatar billede palito Nybegynder
02. november 2007 - 08:51 #3
læg et svar jakobdo
Avatar billede jakobdo Ekspert
02. november 2007 - 09:08 #4
Svar!
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
Vi tilbyder markedets bedste kurser inden for webudvikling

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