| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139 | <?php defined('SYSPATH') OR die('No direct script access.');/** * Provides a shortcut to get Database related objects for [making queries](../database/query). * * Shortcut     | Returned Object * -------------|--------------- * [`DB::query()`](#query)   | [Database_Query] * [`DB::insert()`](#insert) | [Database_Query_Builder_Insert] * [`DB::select()`](#select),<br />[`DB::select_array()`](#select_array) | [Database_Query_Builder_Select] * [`DB::update()`](#update) | [Database_Query_Builder_Update] * [`DB::delete()`](#delete) | [Database_Query_Builder_Delete] * [`DB::expr()`](#expr)     | [Database_Expression] * * You pass the same parameters to these functions as you pass to the objects they return. * * @package    Kohana/Database * @category   Base * @author     Kohana Team * @copyright  (c) 2009 Kohana Team * @license    http://kohanaphp.com/license */class Kohana_DB {	/**	 * Create a new [Database_Query] of the given type.	 *	 *     // Create a new SELECT query	 *     $query = DB::query(Database::SELECT, 'SELECT * FROM users');	 *	 *     // Create a new DELETE query	 *     $query = DB::query(Database::DELETE, 'DELETE FROM users WHERE id = 5');	 *	 * Specifying the type changes the returned result. When using	 * `Database::SELECT`, a [Database_Query_Result] will be returned.	 * `Database::INSERT` queries will return the insert id and number of rows.	 * For all other queries, the number of affected rows is returned.	 *	 * @param   integer  $type  type: Database::SELECT, Database::UPDATE, etc	 * @param   string   $sql   SQL statement	 * @return  Database_Query	 */	public static function query($type, $sql)	{		return new Database_Query($type, $sql);	}	/**	 * Create a new [Database_Query_Builder_Select]. Each argument will be	 * treated as a column. To generate a `foo AS bar` alias, use an array.	 *	 *     // SELECT id, username	 *     $query = DB::select('id', 'username');	 *	 *     // SELECT id AS user_id	 *     $query = DB::select(array('id', 'user_id'));	 *	 * @param   mixed   $columns  column name or array($column, $alias) or object	 * @return  Database_Query_Builder_Select	 */	public static function select($columns = NULL)	{		return new Database_Query_Builder_Select(func_get_args());	}	/**	 * Create a new [Database_Query_Builder_Select] from an array of columns.	 *	 *     // SELECT id, username	 *     $query = DB::select_array(array('id', 'username'));	 *	 * @param   array   $columns  columns to select	 * @return  Database_Query_Builder_Select	 */	public static function select_array(array $columns = NULL)	{		return new Database_Query_Builder_Select($columns);	}	/**	 * Create a new [Database_Query_Builder_Insert].	 *	 *     // INSERT INTO users (id, username)	 *     $query = DB::insert('users', array('id', 'username'));	 *	 * @param   string  $table    table to insert into	 * @param   array   $columns  list of column names or array($column, $alias) or object	 * @return  Database_Query_Builder_Insert	 */	public static function insert($table = NULL, array $columns = NULL)	{		return new Database_Query_Builder_Insert($table, $columns);	}	/**	 * Create a new [Database_Query_Builder_Update].	 *	 *     // UPDATE users	 *     $query = DB::update('users');	 *	 * @param   string  $table  table to update	 * @return  Database_Query_Builder_Update	 */	public static function update($table = NULL)	{		return new Database_Query_Builder_Update($table);	}	/**	 * Create a new [Database_Query_Builder_Delete].	 *	 *     // DELETE FROM users	 *     $query = DB::delete('users');	 *	 * @param   string  $table  table to delete from	 * @return  Database_Query_Builder_Delete	 */	public static function delete($table = NULL)	{		return new Database_Query_Builder_Delete($table);	}	/**	 * Create a new [Database_Expression] which is not escaped. An expression	 * is the only way to use SQL functions within query builders.	 *	 *     $expression = DB::expr('COUNT(users.id)');	 *     $query = DB::update('users')->set(array('login_count' => DB::expr('login_count + 1')))->where('id', '=', $id);	 *     $users = ORM::factory('user')->where(DB::expr("BINARY `hash`"), '=', $hash)->find();	 *	 * @param   string  $string  expression	 * @param   array   parameters	 * @return  Database_Expression	 */	public static function expr($string, $parameters = array())	{		return new Database_Expression($string, $parameters);	}} // End DB
 |