Mysql
 sql >> Base de données >  >> RDS >> Mysql

Erreur MySQL - Commandes désynchronisées ; vous ne pouvez pas exécuter cette commande maintenant

Vous avez la réponse ! Il semble que le pilote mysql de codeigniter ait des bogues dans la gestion des procédures stockées.

J'ai changé les pilotes de mysql en mysqli dans la config/database fichier en changeant

$db['default']['dbdriver'] = 'mysql';

à

$db['default']['dbdriver'] = 'mysqli';

Post que j'ai modifié le system/database/drivers/mysqli/mysqli_result.php fichier et ajouté la fonction ci-dessous

function next_result()
{
  if (is_object($this->conn_id))
  {
      return mysqli_next_result($this->conn_id);
  }
}

et modifié le modèle comme ci-dessous

$db = $this->load->database('mailbox',TRUE);
$qry_res = $db->query('Call circle_pending_p()');

echo $db->_error_message();
$res = $qry_res->result_array();

$qry_res->next_result();
$qry_res->free_result();

if (count($res) > 0) {
      return $res;
} else {
      return 0;
}

Cela a résolu le problème !