Legacy Documentation
You are using the documentation for version 3.5.17. Go here for the latest version or check here for your available upgrades to the latest version.
Raw Queries and Metadata¶
- 
class CI_DB_driver¶
Raw Queries¶
- 
CI_DB_driver::query($sql[, $binds = FALSE])¶
- To submit a query, use the following function: - ee()->db->query('YOUR QUERY HERE'); - The query() function returns a database result object when “read” type queries are run, which you can use to show your results. When “write” type queries are run it simply returns - TRUEor- FALSEdepending on success or failure. When retrieving data you will typically assign the query to your own variable, like this:- $query = ee()->db->query('YOUR QUERY HERE'); - Query Bindings - Bindings enable you to simplify your query syntax by letting the system put the queries together for you. Consider the following example: - $sql = "SELECT * FROM some_table WHERE id = ? AND status = ? AND author = ?"; ee()->db->query($sql, array(3, 'live', 'Rick')); - The question marks in the query are automatically replaced with the values in the array in the second parameter of the query function. - The secondary benefit of using binds is that the values are automatically escaped, producing safer queries. You don’t have to remember to manually escape data; the engine does it automatically for you. - Parameters: - $sql (string) – The SQL query to run
- $binds (array) – Array of query binding data
 - Returns: - The query result - Return type: 
- 
CI_DB_driver::simple_query($sql)¶
- This is a simplified version of the - query()method. It DOES NOT return a database result set, nor does it set the query timer, or compile bind data, or store your query for debugging. It simply lets you submit a query. Most users will rarely use this function.- It returns whatever the database drivers’ “execute” function returns. That typically is - TRUE/- FALSEon success or failure for write type queries such as- INSERT,- DELETEor- UPDATEstatements (which is what it really should be used for) and a resource/object on success for queries with fetchable results.- if (ee()->db->simple_query('YOUR QUERY')) { echo "Success!"; } else { echo "Query failed!"; } - Parameters: - $sql (string) – The SQL query to run
 - Returns: - A - PDOStatementobject on success,- FALSEotherwise- Return type: - PDOStatement/- FALSE
- 
CI_DB_driver::protect_identifiers($item[, $prefix_single = FALSE])¶
- In many databases it is advisable to protect table and field names - for example with backticks in MySQL. Query Builder queries are automatically protected, however if you need to manually protect an identifier you can use: - ee()->db->protect_identifiers('table_name'); - Important - Although the Query Builder will try its best to properly quote any field and table names that you feed it, note that it is NOT designed to work with arbitrary user input. DO NOT feed it with unsanitized user data. - This function will also add a table prefix to your table, assuming you have a prefix specified in your database config file. To enable the prefixing set - TRUE(boolean) via the second parameter:- ee()->db->protect_identifiers('table_name', TRUE); - Parameters: - $item (mixed) – The item to escape
- $prefix_single (boolean) – Set to TRUEto add the prefix to the table name
 - Returns: - The escaped item - Return type: - string 
- 
CI_DB_driver::escape($str)¶
- This function determines the data type so that it can escape only string data. It also automatically adds single quotes around the data so you don’t have to: - $sql = "INSERT INTO table (title) VALUES(".ee()->db->escape($title).")"; - Parameters: - $str (string) – The string to escape
 - Returns: - The escaped string - Return type: - string 
- 
CI_DB_driver::escape_str($str[, $like = FALSE])¶
- This function escapes the data passed to it, regardless of type. Most of the time you’ll use the above function rather than this one. Use the function like this: - $sql = "INSERT INTO table (title) VALUES('".ee()->db->escape_str($title)."')"; - Parameters: - $str (string) – The string to escape
- $like (boolean) – Set to TRUEto escapeLIKEcondition wildcards
 - Returns: - The escaped string - Return type: - string 
- 
CI_DB_driver::escape_like_str($str)¶
- This is just like - escape_str()with the second parameter set as- TRUEto escape- LIKEcondition wildcards:- $search = '20% raise'; $sql = "SELECT id FROM table WHERE column LIKE '%".ee()->db->escape_like_str($search)."%'"; - Parameters: - $str (string) – The string to escape
 - Returns: - The escaped string - Return type: - string 
Query Helpers¶
- 
CI_DB_driver::insert_id()¶
- The insert ID number when performing database inserts. - Returns: - The ID number of the row just inserted - Return type: - int 
- 
CI_DB_driver::affected_rows()¶
- Displays the number of affected rows, when doing “write” type queries (insert, update, etc.). - Note - In MySQL - DELETE FROM TABLEreturns 0 affected rows. The database class has a small hack that allows it to return the correct number of affected rows.- Returns: - The number of affected rows - Return type: - int 
- 
CI_DB_driver::count_all($table)¶
- Permits you to determine the number of rows in a particular table. Submit the table name in the first parameter. Example: - echo ee()->db->count_all('my_table'); // Produces an integer, like 25 - Parameters: - $table (string) – The table to check
 - Returns: - The number of rows in a particular table - Return type: - int 
- 
CI_DB_driver::last_query()¶
- Returns the last query that was run (the query string, not the result): - $str = ee()->db->last_query(); // Produces: SELECT * FROM sometable.... - Returns: - The last query as SQL - Return type: - string 
- 
CI_DB_driver::insert_string($table, $data)¶
- This function simplifies the process of writing database inserts. It returns a correctly formatted SQL insert string. Example: - $data = array('name' => $name, 'email' => $email, 'url' => $url); $str = ee()->db->insert_string('table_name', $data); - The first parameter is the table name, the second is an associative array with the data to be inserted. The above example produces: - INSERT INTO table_name (name, email, url) VALUES ('Rick', '[email protected]', 'example.com') - Parameters: - $table (string) – The table for the query
- $data (array) – The data for the query
 - Returns: - A SQL string that has not been executed, use - query()to run it- Return type: - string 
- 
CI_DB_driver::update_string($table, $data, $where)¶
- This function simplifies the process of writing database updates. It returns a correctly formatted SQL update string: - $data = array('name' => $name, 'email' => $email, 'url' => $url); $where = "author_id = 1 AND status = 'active'"; $str = ee()->db->update_string('table_name', $data, $where); - The first parameter is the table name, the second is an associative array with the data to be updated, and the third parameter is the - WHEREclause. The above example produces:- UPDATE table_name SET name = 'Rick', email = '[email protected]', url = 'example.com' WHERE author_id = 1 AND status = 'active' - Parameters: - $table (string) – The table for the query
- $data (array) – The data for the query
- $where (array) – The data for the WHEREclause
 - Returns: - A SQL string that has not been executed, use - query()to run it- Return type: - string 
Metadata¶
- 
CI_DB_driver::list_tables()¶
- Returns an array containing the names of all the tables in the database you are currently connected to. Example: - $tables = ee()->db->list_tables(); foreach ($tables as $table) { echo $table; } - Returns: - Array of table names - Return type: - array 
- 
CI_DB_driver::table_exists($table_name)¶
- Sometimes it’s helpful to know whether a particular table exists before running an operation on it. Returns a boolean - TRUE/- FALSE. Usage example:- if (ee()->db->table_exists('table_name')) { // some code... } - Parameters: - $table_name (string) – The name of the table to check
 - Returns: - TRUEif the- $table_nameexists,- FALSEotherwise- Return type: - boolean 
- 
CI_DB_driver::list_fields($table_name)¶
- Returns an array containing the field names. This query can be called two ways: - You can supply the table name and call it from the - ee()->db->object:- $fields = ee()->db->list_fields('table_name'); foreach ($fields as $field) { echo $field; } 
- You can gather the field names associated with any query you run by calling the function from your query result object: - $query = ee()->db->query('SELECT * FROM some_table'); foreach ($query->list_fields() as $field) { echo $field; } 
 - Parameters: - $table_name (string) – The name of the table to check
 - Returns: - Array of field names - Return type: - array 
- 
CI_DB_driver::field_exists($field_name, $table_name)¶
- Sometimes it’s helpful to know whether a particular field exists before performing an action. Returns a boolean - TRUE/- FALSE. Usage example:- if (ee()->db->field_exists('field_name', 'table_name')) { // some code... } - Parameters: - $field_name (string) – The name of the field to look for
- $table_name (string) – The name of the table to look in
 - Returns: - TRUEif the- $field_nameexists within- $table_name,- FALSEotherwise- Return type: - boolean 
- 
CI_DB_driver::field_data($table_name)¶
- Returns an array of objects containing field information. - Sometimes it’s helpful to gather the field names or other metadata, like the column type, max length, etc. - Usage example: - $fields = ee()->db->field_data('table_name'); foreach ($fields as $field) { echo $field->name; echo $field->type; echo $field->max_length; echo $field->primary_key; } - If you have run a query already you can use the result object instead of supplying the table name: - $query = ee()->db->query("YOUR QUERY"); $fields = $query->field_data(); - Parameters: - $table_name (string) – The name of the table
 - Returns: - Object containing the following field data: - name- column name
- max_length- maximum length of the column
- primary_key- 1 if the column is a primary key
- type- the type of the column
 - Return type: 
- 
CI_DB_driver::platform()¶
- Outputs the database platform you are running: - echo ee()->db->platform(); - Note - This will only display MySQL since that’s what ExpressionEngine requires, but is included for completeness. - Returns: - The name of the database platform you are running - Return type: - string 
- 
CI_DB_driver::version()¶
- Outputs the database version you are running: - echo ee()->db->version(); - Returns: - The version of the database you’re running - Return type: - string