Avatar billede superboy Nybegynder
14. december 2006 - 18:09 Der er 7 kommentarer

Fejl i kode, skal gribe hente noget fra en database

Hej jeg ska have grebet noget fra en database, men jeg kan ikke få det til at virke og jeg kan ikke helt finde fejlen. Men mit gæt er at det er i meddelelse4.php omkring $fraalbum=$_REQUEST[`album_id`]; og  .$_GET["album_id"].

Og her er et lille diagram over det hele :
http://www.kennethcm.dk/Database.jpg


Meddelelse3.php
<html><body>
<?php
//skab database forbindelse
$db=mysql_connect("localhost", "kennethcm_dk", "pdBuQxpF");
mysql_select_db("kennethcm_dk", $db) or die(mysql_error());

//lav forespørgsel
$recordset=mysql_query("SELECT * FROM album ORDER BY album_id ASC") or die(mysql_error());

//dan tabel
    print "<table>";
        //sålænge der er flere poster i recordset
        while ($poster = mysql_fetch_array($recordset))
        {
            //udskriv et record
            print "<tr><td>Link </td><td>".$poster["album_id"].$poster["album"]."</td><tr><a href=\"medlemmer4.php?sendalbum_id=".$poster["album_id"]."\"><strong>".$poster["album"]."</strong></a><br/>";
}
    print "</table>";

//lukke databasen
mysql_close();
?>
<p>udtræk fra databasen er slut</p>
<?php
print "</body></html>";
?>



Meddelelse4.php

<html><body>
<?php
//skab database forbindelse
$db=mysql_connect("localhost", "kennethcm_dk", "pdBuQxpF");
mysql_select_db("kennethcm_dk", $db) or die(mysql_error());

$fraalbum=$_REQUEST[`album_id`];

//lav forespørgsel
$recordset=mysql_query("SELECT `albumnr`.`album_id` , `numre`.`numre_id` , `numre`.`navn` FROM albumnr, numre WHERE album_id = ` " .$_GET["album_id"]." ` AND (`numre`.`numre_id` = `albumnr`.`numre_id` )");

//dan tabel
    print "<table>";
        //sålænge der er flere poster i recordset
        while ($poster = mysql_fetch_array($recordset))
        {
            //udskriv et record
            print "<tr><td>Link </td><td>".$poster["album_id"].$poster["navn"]."</td><tr>";
        }

    print "</table>";

//lukke databasen
mysql_close();
?>
<p>udtræk fra databasen er slut</p>
<?php
print "</body></html>";
print $fraalbum;
?>
Avatar billede jensgram Nybegynder
14. december 2006 - 18:18 #1
Du kalder din GET-variabel sendalbum_id i linket, men tester på album_id
Avatar billede jensgram Nybegynder
14. december 2006 - 18:18 #2
medd 4:

$fraalbum=$_REQUEST[`album_id`];

->

$fraalbum=$_GET[`sendalbum_id`];
Avatar billede jensgram Nybegynder
14. december 2006 - 18:19 #3
$recordset=mysql_query("SELECT `albumnr`.`album_id` , `numre`.`numre_id` , `numre`.`navn` FROM albumnr, numre WHERE album_id = ` " .$_GET["album_id"]." ` AND (`numre`.`numre_id` = `albumnr`.`numre_id` )");

->

$recordset=mysql_query("SELECT `albumnr`.`album_id` , `numre`.`numre_id` , `numre`.`navn` FROM albumnr, numre WHERE album_id = ` " .$fraalbum." ` AND (`numre`.`numre_id` = `albumnr`.`numre_id` )");
Avatar billede showsource Seniormester
14. december 2006 - 19:32 #4
Den er her ikke gangbar:
album_id = ` " .$_GET["album_id"]." `

skal være
album_id = '" .$_GET["album_id"]."'

eller:

<html><body>
<?php
//skab database forbindelse
$db=mysql_connect("localhost", "kennethcm_dk", "pdBuQxpF");
mysql_select_db("kennethcm_dk", $db) or die(mysql_error());

//lav forespørgsel
$recordset=mysql_query("SELECT * FROM album ORDER BY album_id ASC") or die(mysql_error());

//dan tabel
    print "<table>";
        //sålænge der er flere poster i recordset
        while ($poster = mysql_fetch_array($recordset))
        {
            //udskriv et record
            print "<tr><td>Link </td><td>".$poster["album_id"].$poster["album"]."</td><tr><a href=\"medlemmer4.php?sendalbum_id=".$poster["album_id"]."\"><strong>".$poster["album"]."</strong></a><br/>";
}
    print "</table>";

//lukke databasen
mysql_close();
?>
<p>udtræk fra databasen er slut</p>
<?php
print "</body></html>";
?>



Meddelelse4.php

<html><body>
<?php
//skab database forbindelse
$db=mysql_connect("localhost", "kennethcm_dk", "pdBuQxpF");
mysql_select_db("kennethcm_dk", $db) or die(mysql_error());

$fraalbum= intval($_REQUEST['album_id']);

//lav forespørgsel
$recordset=mysql_query("SELECT `albumnr`.`album_id` , `numre`.`numre_id` , `numre`.`navn` FROM albumnr, numre WHERE album_id = " .$fraalbum."  AND (`numre`.`numre_id` = `albumnr`.`numre_id` )");

//dan tabel
    print "<table>";
        //sålænge der er flere poster i recordset
        while ($poster = mysql_fetch_array($recordset))
        {
            //udskriv et record
            print "<tr><td>Link </td><td>".$poster["album_id"].$poster["navn"]."</td><tr>";
        }

    print "</table>";

//lukke databasen
mysql_close();
?>
<p>udtræk fra databasen er slut</p>
<?php
print "</body></html>";
print $fraalbum;
?>
Avatar billede showsource Seniormester
14. december 2006 - 19:33 #5
intval laver $_REQUEST['album_id'] til et tal
Avatar billede showsource Seniormester
14. december 2006 - 19:34 #6
Og den her var heller ikke go'

$fraalbum=$_REQUEST[`album_id`];

enten

$fraalbum=$_REQUEST['album_id'];

eller

$fraalbum=$_REQUEST["album_id"];
Avatar billede jensgram Nybegynder
14. december 2006 - 19:52 #7
showsource > Ja, det havde jeg så slet ikke set :O
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