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

Chiamata alla procedura memorizzata in codeigniter

Seguo il blog del Sig. Tim Brownlaw:
http://ellislab. com/forums/viewthread/73714/#562711

Per prima cosa, modifica application/config/config.php, riga 55.

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

Quindi, aggiungi quanto segue in mysqli_result.php a cui manca questo comando per qualche strano motivo (sotto /system/database/drivers/mysqli/mysqli_result.php).

/**
  * Read the next result
  *
  * @return  null
  */   
 function next_result()
 {
     if (is_object($this->conn_id))
     {
         return mysqli_next_result($this->conn_id);
     }
 }

Quindi, nel tuo modello, aggiungi $result->next_result() .

Di seguito è riportato il mio esempio.

function list_sample($str_where, $str_order, $str_limit)
{
   $qry_res    = $this->db->query("CALL rt_sample_list('{$str_where}', '{$str_order}', '{$str_limit}');");

   $res        = $qry_res->result();

   $qry_res->next_result(); // Dump the extra resultset.
   $qry_res->free_result(); // Does what it says.

   return $res;
}