Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/mysql/72.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
MySQL语法错误,但仅当通过PHP使用时_Php_Mysql_Syntax - Fatal编程技术网

MySQL语法错误,但仅当通过PHP使用时

MySQL语法错误,但仅当通过PHP使用时,php,mysql,syntax,Php,Mysql,Syntax,我试图在我的数据库中重新散列用户ID,但我被卡住了 <?php include("session.php"); include("functions.php"); $conn = ConnectMySQL(); setTimezone($session->username); $sql = "SELECT username, userid FROM users"; $result = mysql_query($sql) or die(mysql_error()); while($r

我试图在我的数据库中重新散列用户ID,但我被卡住了

<?php
include("session.php");
include("functions.php");
$conn = ConnectMySQL();
setTimezone($session->username);

$sql = "SELECT username, userid FROM users";
$result = mysql_query($sql) or die(mysql_error());
while($rows = mysql_fetch_array($result)){
    $username = $rows['username'];
    $old = mysql_real_escape_string($rows['userid']);
    $new = mysql_real_escape_string($session->generateRandID());

    $moresql = "START TRANSACTION;
                UPDATE users SET userid='$new' WHERE userid='$old';
                UPDATE comments SET user='$new' WHERE user='$old';
                UPDATE forum_posts SET poster_name='$new' WHERE poster_name='$old';
                UPDATE forum_topics SET topic_poster_name='$new' WHERE topic_poster_name='$old';
                UPDATE images SET author='$new' WHERE author='$old';
                UPDATE likes SET user='$new' WHERE user='$old';
                UPDATE music SET author='$new' WHERE author='$old';
                UPDATE ratings SET user='$new' WHERE user='$old';
                COMMIT;";
    $newresult = mysql_query($moresql) or die(mysql_error());
    if(!$newresult){echo "There was a problem with changing $username's hash. \n";}
    else{echo "Changed $username's hash<i>!</i> \n";}
}
mysql_close($conn);
?>
没有其他错误-我不知道这是什么。 提前感谢,


Sam

mysql\u query()不支持多个查询。一次必须执行一个查询。请参见以下内容中的

不能通过php向数据库发送一系列查询。考虑在实际数据库上编写一个过程,然后从PHP.< /P>调用它。
此外,这些函数已弃用。你应该考虑一个不同的图书馆。是一种流行的方法。

我在处理事务时通常使用的想法如下(半伪代码):

请注意,根据这种想法,如果查询失败,则必须抛出异常:

PDO可以做到这一点,这取决于您如何配置它 请参见PDO::setAttribute 和PDO::ATTR_ERRMODE和PDO::ERRMODE_异常 否则,对于其他一些API,您可能必须测试用于执行查询的函数的结果,然后自己抛出异常

不幸的是,这并没有什么神奇之处:您不能只是将一条指令放在某个地方并让事务自动完成:您仍然必须指定在事务中必须执行哪一组查询

例如,通常情况下,在事务之前(在开始之前)会有两个查询,在事务之后(在提交或回滚之后)会有另外两个查询;无论事务中发生了什么(或没有发生),您都希望执行这些查询

=====================================================

您也可以使用mysqli来实现同样的功能

<?php
$link = mysqli_connect("localhost", "my_user", "my_password", "world");

/* check connection */
if (mysqli_connect_errno()) {
    printf("Connect failed: %s\n", mysqli_connect_error());
    exit();
}

/* disable autocommit */
mysqli_autocommit($link, FALSE);

mysqli_query($link, "CREATE TABLE myCity LIKE City");
mysqli_query($link, "ALTER TABLE myCity Type=InnoDB");
mysqli_query($link, "INSERT INTO myCity SELECT * FROM City LIMIT 50");

/* commit insert */
mysqli_commit($link);

完全不相关,但是您的
if(!$newresult)
行将永远不会运行,因为
$newresult
等于
FALSE
的情况已经被
或die(mysql_error())覆盖。只是要记住一些事情。
mysql_query() sends a unique query (multiple queries are not supported)
try {
    // First of all, let's begin a transaction
    $db->beginTransaction();

    // A set of queries ; of one fails, an exception should be thrown
    $db->query('first query');
    $db->query('second query');
    $db->query('third query');

    // If we arrive here, it means that no exception was thrown
    // i.e. no query has failed ; and we can commit the transaction
    $db->commit();
} catch (Exception $e) {
    // An exception has been thrown
    // We must rollback the transaction
    $db->rollback();
}
<?php
$link = mysqli_connect("localhost", "my_user", "my_password", "world");

/* check connection */
if (mysqli_connect_errno()) {
    printf("Connect failed: %s\n", mysqli_connect_error());
    exit();
}

/* disable autocommit */
mysqli_autocommit($link, FALSE);

mysqli_query($link, "CREATE TABLE myCity LIKE City");
mysqli_query($link, "ALTER TABLE myCity Type=InnoDB");
mysqli_query($link, "INSERT INTO myCity SELECT * FROM City LIMIT 50");

/* commit insert */
mysqli_commit($link);