Mysql
 sql >> Database >  >> RDS >> Mysql

Errore MySQL - Comandi non sincronizzati; non puoi eseguire questo comando ora

Hai la risposta! Sembra che il driver mysql di codeigniter abbia dei bug che gestiscono le procedure memorizzate.

Ho cambiato i driver da mysql a mysqli nel config/database file modificando

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

a

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

Post che ho modificato il system/database/drivers/mysqli/mysqli_result.php file e aggiunto la funzione sottostante

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

e modificato il modello come di seguito

$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;
}

Questo ha risolto il problema!