Avatar billede wetdog Nybegynder
20. juli 2006 - 21:03 Der er 5 kommentarer og
1 løsning

dynamisk database tabel

Hej

Hvordan får jeg fat i navnet på feltet i en tabel samtidig med jeg hiver resultatet af min query:

$sql = "SELECT * FROM tabel";
$res = mysql_query($sql);

while($row=mysql_fetch_assoc($res) {
  echo $navn_på_felt . " - " . $row[0];
}
Avatar billede pidgeot Nybegynder
20. juli 2006 - 21:15 #1
while($row=mysql_fetch_assoc($res)) {
  foreach($row as $key => $value)
  {
    echo $key . " - " . $value;
  }
}

Det du selv kom med ville hverken skrive det ene eller det andet ud - ikke kun fordi du har glemt en afsluttende parantes ved din while, men mere fordi fetch_assoc kun henter ud ved feltnavne, ikke med et 0-baseret indeks.

Hvis du KUN skal bruge det første felt, ville jeg hente navnet ud på denne måde:

$fieldres=mysql_query("DESCRIBE tabel");
$fieldname=mysql_result($fieldres,0);

...og så bruge det i min select.
Avatar billede gizmo-gizmo Nybegynder
20. juli 2006 - 21:19 #2
Et andet bud:

while($row = mysql_fetch_assoc($res))
{
  echo key($row) . " = " . current($row) . "<br>";
  next($r);
  echo key($row) . " = " . current($row) . "<br>";
}
Avatar billede pidgeot Nybegynder
20. juli 2006 - 21:19 #3
Alternativt kan dette i øvrigt også bruges:

$sql = "SELECT * FROM tabel";
$res = mysql_query($sql);
$fieldname = mysql_field_name($res,0);

while($row=mysql_fetch_assoc($res)) {
  echo $fieldname . " - " . $row[$fieldname];
}
Avatar billede gizmo-gizmo Nybegynder
20. juli 2006 - 21:20 #4
Smart løsning med at bruge mysql_field_name ;)
Avatar billede wetdog Nybegynder
20. juli 2006 - 21:24 #5
det var denne jeg efterlyste:

while($row=mysql_fetch_assoc($res)) {
  foreach($row as $key => $value)
  {
    echo $key . " - " . $value;
  }

smider du et svar?
Avatar billede pidgeot Nybegynder
20. juli 2006 - 21:28 #6
Så gerne :)
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