Avatar billede fozie Nybegynder
15. februar 2008 - 23:19 Der er 5 kommentarer og
1 løsning

Mærkelig forum fejl.

Hej.
Jeg får en  mærkelig fejl når jeg prøver at poste en trod i mit forum.


Fejlen:
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.

Her er min kode:




<table width="400" border="0" align="center" cellpadding="0" cellspacing="1" bgcolor="#CCCCCC">
<tr>
<form id="form1" name="form1" method="post" action="tilfoej.php">
<td>
<table width="100%" height="352" border="0" cellpadding="3" cellspacing="1" bgcolor="#FFFFFF">
<tr>
<td colspan="3" bgcolor="#E6E6E6"><strong>Opret ny topic</strong> </td>
</tr>
<tr>
<td width="14%"><strong>Overskrift</strong></td>
<td width="2%">:</td>
<td width="84%"><input name="topic" type="text" id="topic" size="50" /></td>
</tr>
<tr>
<td valign="top"><strong>Tekst:</strong></td>
<td valign="top">:</td>
<td><textarea name="detail" cols="80" rows="10" id="detail"></textarea></td>
</tr>
<tr>
<td><strong>Navn</strong></td>
<td>:</td>
<td><input name="name" type="text" id="name" size="50" /></td>
</tr>
<tr>
<td>&nbsp;</td>
<td>&nbsp;</td>
<td><input type="submit" name="Submit" value="Opret" /></td>
</tr>
</table>
</td>
</form>
</tr>
</table>
<?php
$query = mysql_query("SELECT `ip` FROM `banned` WHERE `ip` = '". $_SERVER["REMOTE_ADDR"] ."'");

if(mysql_num_rows($query) != 0) {
die("Du er banned");
}
?>
<font face="Tahoma">
<?php
$host="localhost";
$username="fozie_dk";
$password="";
$db_name="fozie_dk";
$tbl_name="forum_question";


// Connect to server and select database.
mysql_connect("$host", "$username", "$password")or die("cannot connect");
mysql_select_db("$db_name")or die("cannot select DB");

if($_POST){

$topic=$_POST['topic'];
$detail=$_POST['detail'];
$name=$_POST['navn'];
$datetime=date("d/m/y h:i:s");

if(empty($_POST['name']))die("Navn tak.");
if(empty($_POST['topic']))die("Overskrift tak.");
if(empty($_POST['detail']))die("Besked tak.");
if($_POST['name'] == 'Fozie')die("Du skal ikke hedde fozie, det er reserveret :\)");
else {

mysql_query("INSERT INTO $tbl_name(topic, detail, name, dateogtime)VALUES('$topic', '$detail', '$name', '$datetime')) OR DIE(mysql_error());


echo "Tilføjet";
}
}
?>
Avatar billede dkfire Nybegynder
15. februar 2008 - 23:31 #1
Avatar billede olebole Juniormester
15. februar 2008 - 23:34 #2
<ole>

Backtick altid felt- og tabelnavne - og så vær omhyggelig med mellemrum i SQL-sætningen:

mysql_query("INSERT INTO `".$tbl_name."` (`topic`, `detail`, `name`, `dateogtime`) VALUES ('$topic', '$detail', '$name', '$datetime')) OR DIE(mysql_error());

/mvh
</bole>
Avatar billede dkfire Nybegynder
15. februar 2008 - 23:38 #3
Prøv lige og rette:
mysql_query("INSERT INTO $tbl_name(topic, detail, name, `datetime`)VALUES('$topic', '$detail', '$name', '$datetime'")) OR DIE(mysql_error());
til:
mysql_query("INSERT INTO `".$tbl_name."` (`topic`, `detail`, `name`, `dateogtime`) VALUES ('$topic', '$detail', '$name', '$datetime')") or die(mysql_error());

En god måde at lave debug er også noget i stil med:
$sqlquery = "INSERT INTO `".$tbl_name."` (`topic`, `detail`, `name`, `dateogtime`) VALUES ('$topic', '$detail', '$name', '$datetime')";
mysql_query($sqlquery) or die(mysql_error()."<br/> Debug: ".$sqlquery);
Avatar billede fozie Nybegynder
26. februar 2008 - 22:48 #4
Ingen af dem var rigtige, bare glem det.
Avatar billede olebole Juniormester
26. februar 2008 - 23:21 #5
- selvtak :)
Avatar billede dkfire Nybegynder
28. februar 2008 - 12:01 #6
Jamen det var så lidt
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