5

データベース内のユーザー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);
?>

クエリ全体はPHPMyAdminを介して完全に正常に機能し、明らかにゼロ行を返します。しかし、PHPで実際の値を渡して試してみると、ひどいことになります。

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 'UPDATE users SET userid='b8aca4b680707453fa4dfe1bf1d0fddb' WHERE userid='8' at line 2

他にエラーはありません-私はそれが何であるかを考えるのに途方に暮れています。前もって感謝します、

サム

4

3 に答える 3

7

複数のクエリはmysql_query()ではサポートされていません。一度に1つのクエリを実行する必要があります。http://php.net/manual/en/function.mysql-query.phpを参照してください

于 2012-09-10T16:16:17.607 に答える
2

ドキュメントから:

mysql_query() sends a unique query (multiple queries are not supported)

PHPを介して一連のクエリをデータベースに送信することはできません。実際のデータベースにプロシージャを記述し、それをphpから呼び出すことを検討してください。

また、これらの関数は非推奨になりました。別のライブラリを検討する必要があります。 PDOは人気があります。

于 2012-09-10T16:17:15.330 に答える
1

トランザクションを操作するときに私が一般的に使用するアイデアは、次のようになります(半擬似コード):

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();
}

このアイデアでは、クエリが失敗した場合、例外をスローする必要があることに注意してください。

PDOは、構成方法に応じて、これを実行できます。PDO::setAttributeおよびPDO::ATTR_ERRMODEおよびPDO:: ERRMODE_EXCEPTIONを参照してください。それ以外の場合、他の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);
于 2012-09-10T16:20:12.177 に答える