Команды MySqli не синхронизированы; вы не можете запустить эту команду сейчас

Я конвертировал свой регистрационный скрипт из mysql в mysqli. Я отлично работал как mysql, но теперь он дает мне ошибку

Commands out of sync; you can't run this command now 

Это функция, которую я использую для регистрации пользователя

 function register_user($register_data) { global $myConnection; array_walk($register_data, 'array_sanitize'); //Make the array readable and seperate the fields from data $fields = '`' . implode('`, `', array_keys($register_data)) . '`'; $data = '\'' . implode('\', \'', $register_data) . '\''; //Insert the data and email an activation email to the user mysqli_query($myConnection, "INSERT INTO `members` ($fields) VALUES ($data)") or die(mysqli_error($myConnection)); email($register_data['mem_email'], 'Activate your account', "Hello " . $register_data['mem_first_name'] . ",\n\nThank you for creating an account with H Fencing. Please use the link below to activate your account so we can confirm you identity:\n\nhttp://blah.blah.co.uk/activate.php?mem_email=" . $register_data['mem_email'] . "&email_code=" . $register_data['email_code'] . "\n\n - David & Jay "); } 

Письмо отправляется с правильными данными из моего массива. Однако данные не вставляются в базу данных, и я получаю упомянутую выше ошибку. Раньше я никогда не сталкивался с этой ошибкой.

Related of "Команды MySqli не синхронизированы; вы не можете запустить эту команду сейчас"

Если вы получаете команды не синхронизированы; вы не можете запустить эту команду сейчас в своем клиентском коде , вы вызываете клиентские функции в неправильном порядке.

Это может произойти, например, если вы используете mysql_use_result () и попытаетесь выполнить новый запрос, прежде чем вы вызовете mysql_free_result (). Это также может произойти, если вы попытаетесь выполнить два запроса, которые возвращают данные, не вызывая mysql_use_result () или mysql_store_result () между ними.

Отсюда: http://dev.mysql.com/doc/refman/5.0/en/commands-out-of-sync.html

Обновить

Если вы сделаете переменную для запроса и вставьте переменную непосредственно в нечто вроде MySQL Workbench, вы можете проверить синтаксис перед выполнением.

 <?php function myConnection(){ $myConnection = mysqli_connect('localhost', 'my_user', 'my_password', 'my_db'); return $myConnection; } function register_user($register_data) { array_walk($register_data, 'array_sanitize'); //Make the array readable and seperate the fields from data $fields = '`' . implode('`, `', array_keys($register_data)) . '`'; $data = "'" . implode("', '", $register_data) . "'"; //Insert the data and email an activation email to the user $query = "INSERT INTO `members` ($fields) VALUES ($data)"; $myNewConnection = myConnection(); if($result = mysqli_query($myNewConnection, $query)){ email($register_data['mem_email'], 'Activate your account', "Hello " . $register_data['mem_first_name'] . ",\n\nThank you for creating an account with H Fencing. Please use the link below to activate your account so we can confirm you identity:\n\nhttp://blah.blah.co.uk/activate.php?mem_email=" . $register_data['mem_email'] . "&email_code=" . $register_data['email_code'] . "\n\n - David & Jay "); mysqli_free_result($result); return ("Success"); } else { echo $query; die(mysqli_error($myNewConnection)); } } ?>