mysql_query():提供的参数不是有效的MySQL-Link资源

时间:2011-05-24 01:26:17

标签: php mysql forms

我一直在尝试从我的表单中插入一个示例数据,但是我总是在执行$ 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);
?>

我不知道我做错了什么。

1 个答案:

答案 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。写上面的代码让我觉得很脏。