我一直在尝试从我的表单中插入一个示例数据,但是我总是在执行$ result时遇到语法错误。
index.php的相关部分:
<form method="post" action="form.php">
<ul >
<li>
<label for="accession_number">Accession Number</label>
<input id="accession_number" name="accession_number" type="text" maxlength="6" value=""/>
</li>
</ul>
</form>
以及来自form.php的部分:
<?php
$connection = mysql_connect($server, $username, $password) or die('Could not connect'.mysql_error());
mysql_select_db($database, $connection) or die("Cannot select db.");
$accession_number = $_POST['accession_number'];
$query = "INSERT INTO top (accession_number) ".
"VALUES ($accession_number)";
var_dump($query);
mysql_error();
$result = mysql_query($$query, connection) or die('Error querying database.');
mysql_close($connection);
?>
我不知道我做错了什么。
答案 0 :(得分:6)
mysql_query()
的参数顺序错误。
此
$result = mysql_query($connection, $query)
应该是
$result = mysql_query($query, $connection)
http://php.net/manual/en/function.mysql-query.php
资源mysql_query(string $ query [,resource $ link_identifier])
当我说使用mysql_error()
时,我的意思是只有出现明显的错误。试试这样的事情
if (isset($_POST['accession_number'])) {
$accession_number = $_POST['accession_number'];
$query = sprintf('INSERT INTO `top` (accession_number) VALUES (%d)',
$accession_number);
$result = mysql_query($query);
if (false === $result) {
throw new Exception('Error in query you have, hmmm: ' . mysql_error());
}
// and so on
我强烈建议完全抛弃MySQL库并转向PDO。写上面的代码让我觉得很脏。