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

Kalder lagret procedure i kodetænder

Jeg følger hr. Tim Brownlaws blog:
http://ellislab. com/forums/viewthread/73714/#562711

Først skal du ændre application/config/config.php, linje 55.

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

Tilføj derefter følgende til mysqli_result.php, der mangler denne kommando af en eller anden mærkelig grund (under /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);
     }
 }

Tilføj derefter $result->next_result() i din model .

Nedenfor er mit eksempel.

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


  1. hvordan kan man sammenkæde strenge?

  2. Hvordan opretter man LEFT JOIN med SELECT underforespørgsel ved hjælp af QueryBuilder i Doctrine 2?

  3. Kaldnotation for PL/SQL-underrutiner i Oracle-databasen

  4. Laravel Delete Query Builder