Sto cercando di ri-hash ID utente nel mio database, ma mi sto bloccando.Errore di sintassi MySQL, ma solo quando si utilizza tramite PHP
<?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);
?>
L'intera query funziona perfettamente con PHPMyAdmin, restituisce ovviamente zero righe. Ma quando provo con valori effettivi di essere passati attraverso di essa utilizzarlo con PHP ottiene succhiare:
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
Non ci sono altri errori - Sono in perdita di pensare a quello che è. Grazie in anticipo,
Sam
Completamente estranei, ma il vostro 'if (! $ newresult)' linea sarà mai essere eseguito perché il caso in cui '$ newresult' è uguale a' FALSE' è già coperto da 'o die (mysql_error());'. Solo qualcosa da tenere a mente. – Palladium