Avatar billede bjarkeml Nybegynder
05. juni 2008 - 21:25 Der er 3 kommentarer og
1 løsning

PHP menu træ problem

Jeg får en fejl der lyder:
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ' at line 1

Koden:
<?php require_once('Connections/cms.php');

if (!function_exists("GetSQLValueString")) {
function GetSQLValueString($theValue, $theType, $theDefinedValue = "", $theNotDefinedValue = "")
{
  $theValue = get_magic_quotes_gpc() ? stripslashes($theValue) : $theValue;

  $theValue = function_exists("mysql_real_escape_string") ? mysql_real_escape_string($theValue) : mysql_escape_string($theValue);

  switch ($theType) {
    case "text":
      $theValue = ($theValue != "") ? "'" . $theValue . "'" : "NULL";
      break;   
    case "long":
    case "int":
      $theValue = ($theValue != "") ? intval($theValue) : "NULL";
      break;
    case "double":
      $theValue = ($theValue != "") ? "'" . doubleval($theValue) . "'" : "NULL";
      break;
    case "date":
      $theValue = ($theValue != "") ? "'" . $theValue . "'" : "NULL";
      break;
    case "defined":
      $theValue = ($theValue != "") ? $theDefinedValue : $theNotDefinedValue;
      break;
  }
  return $theValue;
}
}

mysql_select_db($database_cms, $cms);
$query_rsVisSider = "SELECT * FROM sider";
$rsVisSider = mysql_query($query_rsVisSider, $cms) or die(mysql_error());
$row_rsVisSider = mysql_fetch_assoc($rsVisSider);
$totalRows_rsVisSider = mysql_num_rows($rsVisSider);
?><?php require_once('Connections/cms.php');

$query_rsNav = "SELECT * FROM sider";
$rsNav = mysql_query($query_rsNav, $cms) or die(mysql_error());

// top of page under $rsNav
$rsNav2 = mysql_query($query_rsNav, $cms) or die(mysql_error());

$colname_rsTop = (!isset($_GET['id'])) ? "id" : ((get_magic_quotes_gpc()) ? $_GET['id'] : addslashes($_GET['id']));
$menu = (empty($_GET['uID'])) ? 'sider' : 'undersider';
$type = (empty($_GET['uID'])) ? 'main' : 'sub';

$query_rs = "SELECT * FROM $menu WHERE id = $colname_rsTop";
$rs = mysql_query($query_rs, $cms) or die(mysql_error());
$row_rs = mysql_fetch_assoc($rs);
$totalRows_rs = mysql_num_rows($rs);

$colname_rsSub = (!isset($_GET['uID'])) ? $row_rs['id'] : ((get_magic_quotes_gpc()) ? $_GET['uID'] : addslashes($_GET['uID']));

$query_rsSub = "SELECT * FROM undersider WHERE uID = $colname_rsSub";
$rsSub = mysql_query($query_rsSub, $cms) or die(mysql_error());
//$row_rsSub = mysql_fetch_assoc($rsSub);
$totalRows_rsSub = mysql_num_rows($rsSub);

?>
<html>
<head>
<title>index2</title>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
<link rel="StyleSheet" href="style.css" type="text/css">
</head>
<body>
<?php
while ($row_rsNav2 = mysql_fetch_assoc($rsNav2))
{
    echo '<a class="style4" href="redigerside.php?id=' . $row_rsNav2['id'] . '">' . $row_rsNav2['navn'] . '</a><br>'; 

    if ($row_rsNav2['id'] == $colname_rsSub)
    {
        while ($row_rsSub = mysql_fetch_assoc($rsSub))
        {
            echo '<span class="alm"> - </span><a class="style4" href="redigerunderside.php?id=' . $row_rsSub['id'] . '&uID=' . $row_rsSub['uID'] . '">' . $row_rsSub['navn'] . '</a><br>';
        }
    }
}
?>
</body>

Når der er noget i tabellen "sider" så viser den det og så er der heller ikke nogen problemer. Nå jeg så sletter det, så der ikke er nogen rækker i tabellen sider så kommer den med fejlen. Hvad kan der være galt? Koden laver et php menu træ, eks.:

1
- 1.1
- 1.2
2
3
- 3.1
- osv..
Avatar billede AnyFellow Mester
06. juni 2008 - 08:37 #1
Når du laver en forspørgsel til din database, kan du ikke bare starte med at hente data ud, såfremt du ikke er sikker på der er data at hente.

Du skal sætte en kontrol ind først:

mysql_select_db($database_cms, $cms);
$query_rsVisSider = "SELECT * FROM sider";
$rsVisSider = mysql_query($query_rsVisSider, $cms) or die(mysql_error());

if (mysql_result(($query_antalkampe),0) > 0) {
    $row_rsVisSider = mysql_fetch_assoc($rsVisSider);
} else {
    $row_rsVisSider = "Ingen data at hente fra databasen";
}
Avatar billede AnyFellow Mester
06. juni 2008 - 14:34 #2
Hov

if (mysql_result(($query_antalkampe),0) > 0) {
    $row_rsVisSider = mysql_fetch_assoc($rsVisSider);
} else {
    $row_rsVisSider = "Ingen data at hente fra databasen";
}

...skulle selvfølgelig have været:
if (mysql_result(($rsVisSider ),0) > 0) {
    $row_rsVisSider = mysql_fetch_assoc($rsVisSider);
} else {
    $row_rsVisSider = "Ingen data at hente fra databasen";
}
Avatar billede bjarkeml Nybegynder
06. juni 2008 - 19:30 #3
jeg ved ikke rigtig hvad jeg gjorde, men lige pludselig virkede det:

$colname_rsTop = "-1";
if (isset($_GET['id'])) {
  $colname_rsTop = $_GET['id'];
}

i stedet for:

$colname_rsTop = (!isset($_GET['id'])) ? "id" : ((get_magic_quotes_gpc()) ? $_GET['id'] : addslashes($_GET['id']));

og

$query_rsSub = sprintf("SELECT * FROM undersider WHERE uID = %s", GetSQLValueString($colname_rsSub, "text"));

i stedet for:

$query_rsSub = "SELECT * FROM undersider WHERE uID = $colname_rsSub";
Avatar billede bjarkeml Nybegynder
18. august 2010 - 13:29 #4
Lukket
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