2012-11-09 23:18:50 +11:00
|
|
|
<?php defined('SYSPATH') OR die('No direct script access.');
|
2010-08-21 14:43:03 +10:00
|
|
|
/**
|
2011-05-13 16:00:25 +10:00
|
|
|
* 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.
|
2010-08-21 14:43:03 +10:00
|
|
|
*
|
|
|
|
* @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.
|
|
|
|
*
|
2012-11-09 23:18:50 +11:00
|
|
|
* @param integer $type type: Database::SELECT, Database::UPDATE, etc
|
|
|
|
* @param string $sql SQL statement
|
2010-08-21 14:43:03 +10:00
|
|
|
* @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'));
|
|
|
|
*
|
2012-11-09 23:18:50 +11:00
|
|
|
* @param mixed $columns column name or array($column, $alias) or object
|
2010-08-21 14:43:03 +10:00
|
|
|
* @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'));
|
|
|
|
*
|
2012-11-09 23:18:50 +11:00
|
|
|
* @param array $columns columns to select
|
2010-08-21 14:43:03 +10:00
|
|
|
* @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'));
|
|
|
|
*
|
2012-11-09 23:18:50 +11:00
|
|
|
* @param string $table table to insert into
|
|
|
|
* @param array $columns list of column names or array($column, $alias) or object
|
2010-08-21 14:43:03 +10:00
|
|
|
* @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');
|
|
|
|
*
|
2012-11-09 23:18:50 +11:00
|
|
|
* @param string $table table to update
|
2010-08-21 14:43:03 +10:00
|
|
|
* @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');
|
|
|
|
*
|
2012-11-09 23:18:50 +11:00
|
|
|
* @param string $table table to delete from
|
2010-08-21 14:43:03 +10:00
|
|
|
* @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)');
|
2011-05-13 16:00:25 +10:00
|
|
|
* $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();
|
2010-08-21 14:43:03 +10:00
|
|
|
*
|
2012-11-09 23:18:50 +11:00
|
|
|
* @param string $string expression
|
|
|
|
* @param array parameters
|
2010-08-21 14:43:03 +10:00
|
|
|
* @return Database_Expression
|
|
|
|
*/
|
2012-11-09 23:18:50 +11:00
|
|
|
public static function expr($string, $parameters = array())
|
2010-08-21 14:43:03 +10:00
|
|
|
{
|
2012-11-09 23:18:50 +11:00
|
|
|
return new Database_Expression($string, $parameters);
|
2010-08-21 14:43:03 +10:00
|
|
|
}
|
|
|
|
|
|
|
|
} // End DB
|