$query = $this->db->get('mytable'); // Produces: SELECT * FROM mytable
第二和第三个参数用于设置 LIMIT 子句:
$query = $this->db->get('mytable', 10, 20);
// Executes: SELECT * FROM mytable LIMIT 20, 10
// (in MySQL. Other databases have slightly different syntax)
你应该已经注意到了,上面的方法的结果都赋值给了一个 $query 变量,通过这个变量,
我们可以得到查询的结果:
$query = $this->db->get('mytable');
foreach ($query->result() as $row)
echo $row->title;
参考 生成查询结果 页面获取关于生成结果的更多信息。
$this->db->get_compiled_select()
该方法和 $this->db->get() 方法一样编译 SELECT 查询并返回查询的 SQL 语句,
但是,该方法并不执行它。
$sql = $this->db->get_compiled_select('mytable');
echo $sql;
// Prints string: SELECT * FROM mytable
第二个参数用于设置是否重置查询(默认会重置,和使用 $this->db->get() 方法时一样):
echo $this->db->limit(10,20)->get_compiled_select('mytable', FALSE);
// Prints string: SELECT * FROM mytable LIMIT 20, 10
// (in MySQL. Other databases have slightly different syntax)
echo $this->db->select('title, content, date')->get_compiled_select();
// Prints string: SELECT title, content, date FROM mytable LIMIT 20, 10
上面的例子中,最值得注意的是,第二个查询并没有用到 $this->db->from() 方法,
也没有为查询指定表名参数,但是它生成的 SQL 语句中有 FROM mytable 子句。
这是因为查询并没有被重置(使用 $this->db->get() 方法查询会被执行并被重置,
使用 $this->db->reset_query() 方法直接重置)。
$this->db->get_where()
这个方法基本上和上面的方法一样,但它提供了第二个参数可以让你添加一个 WHERE 子句,
而不是使用 db->where() 方法:
$query = $this->db->get_where('mytable', array('id' => $id), $limit, $offset);
阅读下面的 db->where() 方法获取更多信息。
get_where() 方法的前身为 getwhere(), 已废除
$this->db->select()
该方法用于编写查询语句中的 SELECT 子句:
$this->db->select('title, content, date');
$query = $this->db->get('mytable');
// Executes: SELECT title, content, date FROM mytable
如果你要查询表的所有列,可以不用写这个函数,CodeIgniter 会自动查询所有列(SELECT *)。
$this->db->select() 方法的第二个参数可选,如果设置为 FALSE,CodeIgniter 将不保护你的
表名和字段名,这在当你编写复合查询语句时很有用,不会破坏你编写的语句。
$this->db->select('(SELECT SUM(payments.amount) FROM payments WHERE payments.invoice_id=4') AS amount_paid', FALSE);
$query = $this->db->get('mytable');
$this->db->select_max()
该方法用于编写查询语句中的 SELECT MAX(field) 部分,你可以使用第二个参数(可选)重命名结果字段。
$this->db->select_max('age');
$query = $this->db->get('members'); // Produces: SELECT MAX(age) as age FROM members
$this->db->select_max('age', 'member_age');
$query = $this->db->get('members'); // Produces: SELECT MAX(age) as member_age FROM members
$this->db->select_min()
该方法用于编写查询语句中的 SELECT MIN(field) 部分,和 select_max() 方法一样,
你可以使用第二个参数(可选)重命名结果字段。
$this->db->select_min('age');
$query = $this->db->get('members'); // Produces: SELECT MIN(age) as age FROM members
$this->db->select_avg()
该方法用于编写查询语句中的 SELECT AVG(field) 部分,和 select_max() 方法一样,
你可以使用第二个参数(可选)重命名结果字段。
$this->db->select_avg('age');
$query = $this->db->get('members'); // Produces: SELECT AVG(age) as age FROM members
$this->db->select_sum()
该方法用于编写查询语句中的 SELECT SUM(field) 部分,和 select_max() 方法一样,
你可以使用第二个参数(可选)重命名结果字段。
$this->db->select_sum('age');
$query = $this->db->get('members'); // Produces: SELECT SUM(age) as age FROM members
$this->db->from()
该方法用于编写查询语句中的 FROM 子句:
$this->db->select('title, content, date');
$this->db->from('mytable');
$query = $this->db->get(); // Produces: SELECT title, content, date FROM mytable
正如前面所说,查询中的 FROM 部分可以在方法 $this->db->get() 中指定,所以,你可以
选择任意一种你喜欢的方式。
$this->db->join()
该方法用于编写查询语句中的 JOIN 子句:
$this->db->select('*');
$this->db->from('blogs');
$this->db->join('comments', 'comments.id = blogs.id');
$query = $this->db->get();
// Produces:
// SELECT * FROM blogs JOIN comments ON comments.id = blogs.id
如果你的查询中有多个连接,你可以多次调用这个方法。
你可以传入第三个参数指定连接的类型,有这样几种选择:left,right,outer,inner,left
outer 和 right outer 。
$this->db->join('comments', 'comments.id = blogs.id', 'left');
// Produces: LEFT JOIN comments ON comments.id = blogs.id
简单的 key/value 方式:
$this->db->where('name', $name); // Produces: WHERE name = 'Joe'
注意自动为你加上了等号。
如果你多次调用该方法,那么多个 WHERE 条件将会使用 AND 连接起来:
$this->db->where('name', $name);
$this->db->where('title', $title);
$this->db->where('status', $status);
// WHERE name = 'Joe' AND title = 'boss' AND status = 'active'
关联数组方式:
$array = array('name' => $name, 'title' => $title, 'status' => $status);
$this->db->where($array);
// Produces: WHERE name = 'Joe' AND title = 'boss' AND status = 'active'
你也可以在这个方法里包含你自己的比较运算符:
$array = array('name !=' => $name, 'id <' => $id, 'date >' => $date);
$this->db->where($array);
$this->db->where() 方法有一个可选的第三个参数,如果设置为 FALSE,CodeIgniter
将不保护你的表名和字段名。
$this->db->where('MATCH (field) AGAINST ("value")', NULL, FALSE);
$this->db->or_where()
这个方法和上面的方法一样,只是多个 WHERE 条件之间使用 OR 进行连接:
$this->db->where('name !=', $name);
$this->db->or_where('id >', $id); // Produces: WHERE name != 'Joe' OR id > 50
or_where() 方法的前身为 orwhere(), 已废除
$this->db->where_in()
该方法用于生成 WHERE IN 子句,多个子句之间使用 AND 连接
$names = array('Frank', 'Todd', 'James');
$this->db->where_in('username', $names);
// Produces: WHERE username IN ('Frank', 'Todd', 'James')
$this->db->or_where_in()
该方法用于生成 WHERE IN 子句,多个子句之间使用 OR 连接
$names = array('Frank', 'Todd', 'James');
$this->db->or_where_in('username', $names);
// Produces: OR username IN ('Frank', 'Todd', 'James')
$this->db->where_not_in()
该方法用于生成 WHERE NOT IN 子句,多个子句之间使用 AND 连接
$names = array('Frank', 'Todd', 'James');
$this->db->where_not_in('username', $names);
// Produces: WHERE username NOT IN ('Frank', 'Todd', 'James')
$this->db->or_where_not_in()
该方法用于生成 WHERE NOT IN 子句,多个子句之间使用 OR 连接
$names = array('Frank', 'Todd', 'James');
$this->db->or_where_not_in('username', $names);
// Produces: OR username NOT IN ('Frank', 'Todd', 'James')
$this->db->like('title', 'match');
// Produces: WHERE `title` LIKE '%match%' ESCAPE '!'
如果你多次调用该方法,那么多个 WHERE 条件将会使用 AND 连接起来:
$this->db->like('title', 'match');
$this->db->like('body', 'match');
// WHERE `title` LIKE '%match%' ESCAPE '!' AND `body` LIKE '%match% ESCAPE '!'
可以传入第三个可选的参数来控制 LIKE 通配符(%)的位置,可用选项有:'before','after' 和
'both' (默认为 'both')。
$this->db->like('title', 'match', 'before'); // Produces: WHERE `title` LIKE '%match' ESCAPE '!'
$this->db->like('title', 'match', 'after'); // Produces: WHERE `title` LIKE 'match%' ESCAPE '!'
$this->db->like('title', 'match', 'both'); // Produces: WHERE `title` LIKE '%match%' ESCAPE '!'
关联数组方式:
$array = array('title' => $match, 'page1' => $match, 'page2' => $match);
$this->db->like($array);
// WHERE `title` LIKE '%match%' ESCAPE '!' AND `page1` LIKE '%match%' ESCAPE '!' AND `page2` LIKE '%match%' ESCAPE '!'
$this->db->or_like()
这个方法和上面的方法一样,只是多个 WHERE 条件之间使用 OR 进行连接:
$this->db->like('title', 'match'); $this->db->or_like('body', $match);
// WHERE `title` LIKE '%match%' ESCAPE '!' OR `body` LIKE '%match%' ESCAPE '!'
or_like() 方法的前身为 orlike(), 已废除
$this->db->not_like()
这个方法和 like() 方法一样,只是生成 NOT LIKE 子句:
$this->db->not_like('title', 'match'); // WHERE `title` NOT LIKE '%match% ESCAPE '!'
$this->db->or_not_like()
这个方法和 not_like() 方法一样,只是多个 WHERE 条件之间使用 OR 进行连接:
$this->db->like('title', 'match');
$this->db->or_not_like('body', 'match');
// WHERE `title` LIKE '%match% OR `body` NOT LIKE '%match%' ESCAPE '!'
$this->db->group_by()
该方法用于生成 GROUP BY 子句:
$this->db->group_by("title"); // Produces: GROUP BY title
你也可以通过一个数组传入多个值:
$this->db->group_by(array("title", "date")); // Produces: GROUP BY title, date
group_by() 方法前身为 groupby(), 已废除
$this->db->distinct()
该方法用于向查询中添加 DISTINCT 关键字:
$this->db->distinct();
$this->db->get('table'); // Produces: SELECT DISTINCT * FROM table
$this->db->having()
该方法用于生成 HAVING 子句,有下面两种不同的语法:
$this->db->having('user_id = 45'); // Produces: HAVING user_id = 45
$this->db->having('user_id', 45); // Produces: HAVING user_id = 45
你也可以通过一个数组传入多个值:
$this->db->having(array('title =' => 'My Title', 'id <' => $id));
// Produces: HAVING title = 'My Title', id < 45
如果 CodeIgniter 自动转义你的查询,为了避免转义,你可以将第三个参数设置为 FALSE 。
$this->db->having('user_id', 45); // Produces: HAVING `user_id` = 45 in some databases such as MySQL
$this->db->having('user_id', 45, FALSE); // Produces: HAVING user_id = 45
$this->db->or_having()
该方法和 having() 方法一样,只是多个条件之间使用 OR 进行连接。
$this->db->order_by()
该方法用于生成 ORDER BY 子句。
第一个参数为你想要排序的字段名,第二个参数用于设置排序的方向,
可选项有: ASC(升序),DESC(降序)和 RANDOM (随机)。
$this->db->order_by('title', 'DESC');
// Produces: ORDER BY `title` DESC
第一个参数也可以是你自己的排序字符串:
$this->db->order_by('title DESC, name ASC');
// Produces: ORDER BY `title` DESC, `name` ASC
如果需要根据多个字段进行排序,可以多次调用该方法。
$this->db->order_by('title', 'DESC');
$this->db->order_by('name', 'ASC');
// Produces: ORDER BY `title` DESC, `name` ASC
如果你选择了 RANDOM (随机排序),第一个参数会被忽略,但是你可以传入一个
数字值,作为随机数的 seed。
$this->db->order_by('title', 'RANDOM');
// Produces: ORDER BY RAND()
$this->db->order_by(42, 'RANDOM');
// Produces: ORDER BY RAND(42)
order_by() 方法的前身为 orderby(), 已废除
Oracle 暂时还不支持随机排序,会默认使用升序
$this->db->limit()
该方法用于限制你的查询返回结果的数量:
$this->db->limit(10); // Produces: LIMIT 10
第二个参数可以用来设置偏移。
// Produces: LIMIT 20, 10 (in MySQL. Other databases have slightly different syntax)
$this->db->limit(10, 20);
$this->db->count_all_results()
该方法用于获取特定查询返回结果的数量,也可以使用查询构造器的这些方法:
where(),or_where(),like(),or_like() 等等。举例:
echo $this->db->count_all_results('my_table'); // Produces an integer, like 25
$this->db->like('title', 'match');
$this->db->from('my_table');
echo $this->db->count_all_results(); // Produces an integer, like 17
但是,这个方法会重置你在 select() 方法里设置的所有值,如果你希望保留它们,可以将
第二个参数设置为 FALSE
echo $this->db->count_all_results('my_table', FALSE);
$this->db->count_all()
该方法用于获取某个表的总行数,第一个参数为表名:
echo $this->db->count_all('my_table'); // Produces an integer, like 25
查询条件组可以让你生成用括号括起来的一组 WHERE 条件,这能创造出非常复杂的 WHERE 子句,
支持嵌套的条件组。例如:
$this->db->select('*')->from('my_table')
->group_start()
->where('a', 'a')
->or_group_start()
->where('b', 'b')
->where('c', 'c')
->group_end()
->group_end()
->where('d', 'd')
->get();
// Generates:
// SELECT * FROM (`my_table`) WHERE ( `a` = 'a' OR ( `b` = 'b' AND `c` = 'c' ) ) AND `d` = 'd'
条件组必须要配对,确保每个 group_start() 方法都有一个 group_end() 方法与之配对。
$this->db->group_start()
开始一个新的条件组,为查询中的 WHERE 条件添加一个左括号。
$this->db->or_group_start()
开始一个新的条件组,为查询中的 WHERE 条件添加一个左括号,并在前面加上 OR 。
$this->db->not_group_start()
开始一个新的条件组,为查询中的 WHERE 条件添加一个左括号,并在前面加上 NOT 。
$this->db->or_not_group_start()
开始一个新的条件组,为查询中的 WHERE 条件添加一个左括号,并在前面加上 OR NOT 。
$this->db->group_end()
结束当前的条件组,为查询中的 WHERE 条件添加一个右括号。
$this->db->insert()
该方法根据你提供的数据生成一条 INSERT 语句并执行,它的参数是一个**数组**
或一个**对象**,下面是使用数组的例子:
$data = array(
'title' => 'My title',
'name' => 'My Name',
'date' => 'My date'
$this->db->insert('mytable', $data);
// Produces: INSERT INTO mytable (title, name, date) VALUES ('My title', 'My name', 'My date')
第一个参数为要插入的表名,第二个参数为要插入的数据,是个关联数组。
下面是使用对象的例子:
class Myclass {
public $title = 'My Title';
public $content = 'My Content';
public $date = 'My Date';
$object = new Myclass;
$this->db->insert('mytable', $object);
// Produces: INSERT INTO mytable (title, content, date) VALUES ('My Title', 'My Content', 'My Date')
第一个参数为要插入的表名,第二个参数为要插入的数据,是个对象。
所有数据会被自动转义,生成安全的查询语句。
$this->db->get_compiled_insert()
该方法和 $this->db->insert() 方法一样根据你提供的数据生成一条 INSERT 语句,但是并不执行。
$data = array(
'title' => 'My title',
'name' => 'My Name',
'date' => 'My date'
$sql = $this->db->set($data)->get_compiled_insert('mytable');
echo $sql;
// Produces string: INSERT INTO mytable (`title`, `name`, `date`) VALUES ('My title', 'My name', 'My date')
第二个参数用于设置是否重置查询(默认情况下会重置,正如 $this->db->insert() 方法一样):
echo $this->db->set('title', 'My Title')->get_compiled_insert('mytable', FALSE);
// Produces string: INSERT INTO mytable (`title`) VALUES ('My Title')
echo $this->db->set('content', 'My Content')->get_compiled_insert();
// Produces string: INSERT INTO mytable (`title`, `content`) VALUES ('My Title', 'My Content')
上面的例子中,最值得注意的是,第二个查询并没有用到 $this->db->from() 方法,
也没有为查询指定表名参数,但是它生成的 SQL 语句中有 INTO mytable 子句。
这是因为查询并没有被重置(使用 $this->db->insert() 方法会被执行并被重置,
使用 $this->db->reset_query() 方法直接重置)。
这个方法不支持批量插入。
$this->db->insert_batch()
该方法根据你提供的数据生成一条 INSERT 语句并执行,它的参数是一个**数组**
或一个**对象**,下面是使用数组的例子:
$data = array(
array(
'title' => 'My title',
'name' => 'My Name',
'date' => 'My date'
array(
'title' => 'Another title',
'name' => 'Another Name',
'date' => 'Another date'
$this->db->insert_batch('mytable', $data);
// Produces: INSERT INTO mytable (title, name, date) VALUES ('My title', 'My name', 'My date'), ('Another title', 'Another name', 'Another date')
第一个参数为要插入的表名,第二个参数为要插入的数据,是个二维数组。
所有数据会被自动转义,生成安全的查询语句。
$this->db->replace()
该方法用于执行一条 REPLACE 语句,REPLACE 语句根据表的**主键**和**唯一索引**
来执行,类似于标准的 DELETE + INSERT 。
使用这个方法,你不用再手工去实现 select(),update(),delete()
以及 insert() 这些方法的不同组合,为你节约大量时间。
$data = array(
'title' => 'My title',
'name' => 'My Name',
'date' => 'My date'
$this->db->replace('table', $data);
// Executes: REPLACE INTO mytable (title, name, date) VALUES ('My title', 'My name', 'My date')
上面的例子中,我们假设 title 字段是我们的主键,那么如果我们数据库里有一行
的 title 列的值为 'My title',这一行将会被删除并被我们的新数据所取代。
也可以使用 set() 方法,而且所有字段都被自动转义,正如 insert() 方法一样。
$this->db->set()
该方法用于设置新增或更新的数据。
该方法可以取代直接传递数据数组到 insert 或 update 方法:
$this->db->set('name', $name);
$this->db->insert('mytable'); // Produces: INSERT INTO mytable (`name`) VALUES ('{$name}')
如果你多次调用该方法,它会正确组装出 INSERT 或 UPDATE 语句来:
$this->db->set('name', $name);
$this->db->set('title', $title);
$this->db->set('status', $status);
$this->db->insert('mytable');
set() 方法也接受可选的第三个参数($escape),如果设置为 FALSE,数据将不会自动转义。为了说明两者之间的区别,这里有一个带转义的 set() 方法和不带转义的例子。
$this->db->set('field', 'field+1', FALSE);
$this->db->where('id', 2);
$this->db->update('mytable'); // gives UPDATE mytable SET field = field+1 WHERE id = 2
$this->db->set('field', 'field+1');
$this->db->where('id', 2);
$this->db->update('mytable'); // gives UPDATE `mytable` SET `field` = 'field+1' WHERE `id` = 2
你也可以传一个关联数组作为参数:
$array = array(
'name' => $name,
'title' => $title,
'status' => $status
$this->db->set($array);
$this->db->insert('mytable');
或者一个对象:
class Myclass {
public $title = 'My Title';
public $content = 'My Content';
public $date = 'My Date';
$object = new Myclass;
$this->db->set($object);
$this->db->insert('mytable');
$this->db->update()
该方法根据你提供的数据生成一条 UPDATE 语句并执行,它的参数是一个 数组 或一个 对象 ,下面是使用数组的例子:
$data = array(
'title' => $title,
'name' => $name,
'date' => $date
$this->db->where('id', $id);
$this->db->update('mytable', $data);
// Produces:
// UPDATE mytable
// SET title = '{$title}', name = '{$name}', date = '{$date}'
// WHERE id = $id
或者你可以使用一个对象:
class Myclass {
public $title = 'My Title';
public $content = 'My Content';
public $date = 'My Date';
$object = new Myclass;
$this->db->where('id', $id);
$this->db->update('mytable', $object);
// Produces:
// UPDATE `mytable`
// SET `title` = '{$title}', `name` = '{$name}', `date` = '{$date}'
// WHERE id = `$id`
所有数据会被自动转义,生成安全的查询语句。
你应该注意到 $this->db->where() 方法的使用,它可以为你设置 WHERE 子句。
你也可以直接使用字符串形式设置 WHERE 子句:
$this->db->update('mytable', $data, "id = 4");
或者使用一个数组:
$this->db->update('mytable', $data, array('id' => $id));
当执行 UPDATE 操作时,你还可以使用上面介绍的 $this->db->set() 方法。