Oprettet man. d. 27. december 2004 kl. 20:12:49

dl
dl (16.999 point. Point ude: 60)

While i php

Jeg har en database 'MenuSystem'.
Som jeg skal lave et udtræk på.

Mit problem ligger i while ... der kommer den første fejl.
Den anden kommer ved : mysql_free_result($MenuSystemResult);

Hvaad går der galt?



<start kode>

<?php
    Require ($_SERVER["DOCUMENT_ROOT"]."/system/db_ind.inc");
       
    $MenuSystemLink = mysql_connect($mysql_db_host,$mysql_db_username,$mysql_db_pass);
    if (!$MenuSystemLink) {
        die('Could not connect: ' . mysql_error());
    }


    // make MenuSystem the current db for the connection MenuSystemLink
    $MenuSystemLink_db_selected = mysql_select_db('tcwc_dk',$MenuSystemLink);
    if (!$MenuSystemLink_db_selected) {
        die ('Could not connect to db: ' . mysql_error());
    }           

?>   


    <table class="Border" align="center" cellpadding="0" cellspacing="0" width="95%">
       
<?php
    $menu = $_GET["menu"];

    if (isset($menu)) {
        $MenuSystemResult = mysql_query("select * from menusystem where MenuID = '$menu'");

        while ($MenuSystemRow = mysql_fetch_array($MenuSystemResult)) {
            print '<tr>';   
            print '    <td width="100%" colspan="2">' . $MenuSystemRow[MenuPunktName] . '</td>';
            print '</tr>';
        }
        mysql_free_result($MenuSystemResult);
    }

?>

   
    </table>





<?php
    mysql_close($MenuSystemLink);
?>

<slut kode>

Fejl:

Warning: mysql_fetch_array(): supplied argument is not a valid MySQL result resource in /customers/tcwc.dk/tcwc.dk/httpd.www/index.php on line 48

Warning: mysql_free_result(): supplied argument is not a valid MySQL result resource in /customers/tcwc.dk/tcwc.dk/httpd.www/index.php on line 53

Skrevet man. d. 27. december 2004 kl. 20:14:56| #1

arne_v
arne_v (1.005.653 point)
Din query fejler.

prøv:

$MenuSystemResult = mysql_query("select * from menusystem where MenuID = '$menu'") or die(mysql_error());

Skrevet man. d. 27. december 2004 kl. 20:15:49| #2

dl
dl (16.999 point)
hmm ... husk stor og små bogstaver..

Skrevet man. d. 27. december 2004 kl. 20:16:39| #3

dl
dl (16.999 point)
den rigtig : $MenuSystemResult = mysql_query("select * from MenuSystem where MenuID = '$menu'");

Vil du have point ?

Skrevet man. d. 27. december 2004 kl. 20:18:47| #4

arne_v
arne_v (1.005.653 point)
Kun hvis du brugte or die til at finde fejlen med

Skrevet man. d. 27. december 2004 kl. 20:40:38| #5

dl
dl (16.999 point)
nej, det gjore jeh ikke .... MEN jeg vil faktisk godt bruge den ... da jeg så får en fejl kode... hvis det går galt.
;)

//dl

PS. så kom med et svar.

Skrevet man. d. 27. december 2004 kl. 20:42:51| #6

dl
dl (16.999 point)
hvor virker min while nu ikke:

<?php
    $menu = $_GET["menu"];

    if (isset($menu)) {
        $MenuSystemResult = mysql_query("select * from MenuSystem where MenuID = '$menu'");

        while ($MenuSystemRow = mysql_fetch_array($MenuSystemResult)) or die ('Could not fetch array: ' . mysql_error()) {
            print '<tr>';   
            print '    <td width="100%" colspan="2">' . $MenuSystemRow[MenuPunktName] . '</td>';
            print '</tr>';
        }
        mysql_free_result($MenuSystemResult);
    }

?>

Skrevet man. d. 27. december 2004 kl. 20:47:54| #7

arne_v
arne_v (1.005.653 point)
Hvad sker der ?

Skrevet man. d. 27. december 2004 kl. 20:48:33| #8

arne_v
arne_v (1.005.653 point)
Umiddelbart ville jeg tro at

$MenuSystemRow[MenuPunktName]

skulle være

$MenuSystemRow["MenuPunktName"]

Skrevet man. d. 27. december 2004 kl. 20:48:42| #9

arne_v
arne_v (1.005.653 point)
og et svar

Skrevet man. d. 27. december 2004 kl. 20:54:09| #10

dl
dl (16.999 point)
nej, for det virker hvis hvis jeg fjerner :  or die ('Could not fetch array: ' . mysql_error())

og bare køre det som dette:
<?php
    $menu = $_GET["menu"];

    if (isset($menu)) {
        $MenuSystemResult = mysql_query("select * from MenuSystem where MenuID = '$menu'");

        while ($MenuSystemRow = mysql_fetch_array($MenuSystemResult)) {
            print '<tr>'; 
            print '    <td width="100%" colspan="2">' . $MenuSystemRow[MenuPunktName] . '</td>';
            print '</tr>';
        }
        mysql_free_result($MenuSystemResult);
    }

?>

Skrevet man. d. 27. december 2004 kl. 20:56:46| #11

arne_v
arne_v (1.005.653 point)
Hm.

Det er nu også lidt utraditionelt at putte or die på mysql_fetch_array - normalt
er det mysql_query man bruger den på.

Skrevet man. d. 27. december 2004 kl. 20:57:47| #12

dl
dl (16.999 point)
k, det kan jeg da også ... bare jeg kan fejl finde når det er :)

Skrevet man. d. 27. december 2004 kl. 20:58:40| #13

morteeart
morteeart (14.603 point)
put: or die() på mysql_query

sæt @ foran mysql_fetch_array (så slipper du for fejlmeddelsen)

og det hedder: $MenuSystemRow['MenuPunktName'] altså med ' '

Skrevet man. d. 27. december 2004 kl. 21:00:59| #14

dl
dl (16.999 point)
Hvornår bruger man "  og '

Skrevet man. d. 27. december 2004 kl. 21:03:50| #15

morteeart
morteeart (14.603 point)
echo "text";
echo $array['1'];
echo $array['hej'];

Skrevet man. d. 27. december 2004 kl. 21:04:38| #16

dl
dl (16.999 point)
k, takker.

Skrevet man. d. 27. december 2004 kl. 21:05:29| #17

morteeart
morteeart (14.603 point)
og en refferance til manualen:

http://se.php.net/ (...)

Skrevet man. d. 27. december 2004 kl. 21:27:03| #18

arne_v
arne_v (1.005.653 point)
PHP er faktisk ret fleksibel med hensyn til array index.

Jeg har lige siddet og leget lidt.

Prøv og kør det her eksempel:

<?php
$a = array("Linie 1","Linie 2","Linie 3");
print $a[0] . "<br>";
print $a['1'] . "<br>";
print $a["2"] . "<br>";
$b = array('Linie 4','Linie 5','Linie 6');
print $b[0] . '<br>';
print $b['1'] . '<br>';
print $b["2"] . '<br>';
$c = '1';
print $a[$c] . '<br>';
print $a['$c'] . '<br>';
print $a["$c"] . '<br>';
?>

Det skulle gerne vise lidt om hvad man kan og hvad man ikke kan.

Skriv et indlæg




Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] [img]link til billede[/img]
Web- og emailadresser omdannes automatisk til links

Log ind

   

   

Seneste spørgsmål

Udtræk af enkelte felter fra bestemte kolonner i mysql

Oprettet den 11. februar 2012 kl. 19.27
hrole giver 30 point for svar | Giv et svar »

Procentregning

Oprettet den 11. februar 2012 kl. 11.26
sevinding giver 60 point for svar | Giv et svar »

Ville ikke tildele at upload det til database eller komme...

Oprettet den 10. februar 2012 kl. 21.23
tobrukDk giver 15 point for svar | Giv et svar »

Seneste guides

Installer win 7
Den gode bruger


   




Tips & Tricks fra PC World

Teaser billede

Her er fem sjove danske websider du skal kende

Trænger dine lattermuskler til en omgang fitness på dansk? Vi viser vej til fem websider fyldt med humor og vanvittig satire.


Anmeldelser fra PC World

Teaser billede

Test: Denne super-tablet er iPads hårdeste konkurrent

Eee Pad Transformer Prime er frygtindgydende med sin quadcore processor og evne til at trylle sig om til bærbar. Apple bør kigge i bagspejlet, for Asus' tablet-pc kommer buldrende - og gør det...


Seneste blogindlæg

Teaser billede

Tvangslukke spørgsmål: Hvad er den bedste løsning?

Hej Vi har mange åbne spørgsmål på Eksperten. Vi ville gerne tvangslukke dem - så et spørgsmål efter f.eks. 6 måneder lukkes. Men der er et par uklarheder som ville være gode at få lidt input til:...


Nyheder fra PC World

Teaser billede

Nu kan du snart hente Windows 8

Den nye offentlige betaversion af Windows 8 er klar i denne måned.


Nyheder fra Computerworld

Teaser billede

Måske snart slut med Androids helt store problem

Android-platformen har længe været plaget af et særligt problem. Men måske er problemet nu ved at være elimineret.


Kurser
Samarbejdspartnere

Udgiver · © 2012 IDG Danmark A/S · Hørkær 18 · 2730 Herlev · Tlf.: 77 300 300 · Fax: 77 300 301 · Brug af personoplysninger