Avatar billede Nederb Juniormester
29. maj 2012 - 11:45 Der er 3 kommentarer og
1 løsning

Sortering af data

Jeg vil gerne sortere data efter de er hentet første gang fra Mysql databasen.
testside: http://www.neder.dk/dbtest/index.php

Min kode se dådan ud:

<form name="myform" action="<?php echo $_SERVER["PHP_SELF"]; ?>" method="POST">
Sortere efter</ br>
<SELECT name="sortering">
<OPTION  VALUE="i" <?php  if ($sortering=="i") {echo "SELECTED";}?> > ID</OPTION>
<OPTION VALUE="n" <?php  if ($sortering=="n") {echo "SELECTED";}?>> Navn</OPTION>
<OPTION VALUE="f" <?php  if ($sortering=="f") {echo "SELECTED";}?>> Farve</OPTION>
</SELECT>
<INPUT TYPE="submit" VALUE="Vis">
</form>
<?php
    if ($sortering=="i"):
                  $sort="ORDER BY id";
    elseif ($sortering=="n"):
                  $sort="ORDER BY navn";
    elseif ($sortering=="f"):
                  $sort="ORDER BY farve";
endif;

$result = mysql_query("SELECT * FROM  test $sort");
if(!$result) die("MySQL-fejl: ".mysql_error() );
  if (mysql_num_rows($result)) {
while ($row = mysql_fetch_array($result)) {

echo "$row[id] - $row[farve] - $row[navn]<br />";
}
  }
  else {
echo "Der er ingen navne eller farver" ;
  }

mysql_close($conn);

echo "<p>Sorteret efter $sort</p>";
?>

Der kommer ingen fejl til gengæld virjer det ikke
Hvad er der galt?
Avatar billede inteeeL Nybegynder
29. maj 2012 - 13:01 #1
Sortering er ikke defineret, prøv nedenstående:
<?php

$sort = "ORDER BY id"; //Standard
$sortering = 'i'; //Standard
if( isset( $_POST['sortering'])) {
    $sortering = $_POST['sortering'];
    if ($sortering=="i"):
        $sort="ORDER BY id";
    elseif ($sortering=="n"):
        $sort="ORDER BY navn";
    elseif ($sortering=="f"):
        $sort="ORDER BY farve";
    endif;
}

?>

<form name="myform" action="<?php echo $_SERVER["PHP_SELF"]; ?>" method="POST">
    Sortere efter</ br>
    <SELECT name="sortering">
        <OPTION  VALUE="i" <?php  if ($sortering=="i") {echo "SELECTED";}?>> ID</OPTION>
        <OPTION VALUE="n" <?php  if ($sortering=="n") {echo "SELECTED";}?>> Navn</OPTION>
        <OPTION VALUE="f" <?php  if ($sortering=="f") {echo "SELECTED";}?>> Farve</OPTION>
    </SELECT>
    <INPUT TYPE="submit" VALUE="Vis">
</form>

<?php

$result = mysql_query("SELECT * FROM  test $sort");
if(!$result) die("MySQL-fejl: ".mysql_error());
if (mysql_num_rows($result) > 0) {
    while ($row = mysql_fetch_array($result)) {
        echo "$row[id] - $row[farve] - $row[navn]<br />";
    }
}
else {
    echo "Der er ingen navne eller farver" ;
}

mysql_close($conn);

echo "<p>Sorteret efter $sort</p>";

?>
Avatar billede Nederb Juniormester
29. maj 2012 - 13:55 #2
SÅDAN  inteeeL
Det virker
Skriv et svar
Avatar billede inteeeL Nybegynder
29. maj 2012 - 21:20 #3
Svar. :-)
Avatar billede inteeeL Nybegynder
30. maj 2012 - 17:48 #4
Prøver lige en gang til, hvor kommentaren BLIVER oprettet som et 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