CodeIgniter 之数据库操作

浏览1090

在使用数据库之前,我们最好将数据库进行自动连接:config/autoload.php自动加载 $autoload['libraries'] = array('database');
一些常用函数

       选择数据

$this->db->select();

允许你在SQL查询中写 SELECT 部分。

$this->db->where();

$this->db->or_where();

$this->db->where_in();

允许你在SQL查询中写 WHERE部分,其余各种where语句请看手册。

$this->db->get();

运行选择查询语句并且返回结果集。可以获取一个表的全部数据。

$this->db->like();

$this->db->or_like();

$this->db->not_like();

本函数允许你生成 LIKE 子句,在做查询时非常有用,其余语法请看手册。

$this->db->order_by();

帮助你设置一个 ORDER BY 子句。

$this->db->group_by();

允许你编写查询语句中的 GROUP BY 部分:

$this->db->distinct();

为查询语句添加 "DISTINCT" 关键字:

$this->db->having();

允许你为你的查询语句编写 HAVING 部分。

$this->db->limit();

限制查询所返回的结果数量:

 

$this->db->select_max();

为你的查询编写一个 "SELECT MAX(field)"

$this->db->select_min();

为你的查询编写一个 "SELECT MIN(field)" 

$this->db->select_avg();

为你的查询编写一个 "SELECT AVG(field)" 

$this->db->select_sum();

为你的查询编写一个 "SELECT SUM(field)" 

$this->db->join();

允许你编写查询中的JOIN部分。

 

$this->db->count_all_results();

允许你获得某个特定的Active Record查询所返回的结果数量。可以使用Active Record限制函数,例如 where(), or_where(), like(), or_like() 等等。

 

插入数据

$this->db->insert();

生成一条基于你所提供的数据的SQL插入字符串并执行查询。你可以向函数传递 数组 或一个 对象。

$this->db->insert_batch();

一次插入多条数据,生成一条基于你所提供的数据的SQL插入字符串并执行查询。你可以向函数传递 数组 或一个 对象。

$this->db->set();

本函数使您能够设置inserts(插入)updates(更新)值。它可以用来代替那种直接传递数组给插入和更新函数的方式。

 

更新数据

$this->db->update();

根据你提供的数据生成并执行一条update(更新)语句。你可以将一个数组或者对象传递给本函数。

$this->db->update_batch();

Generates an update string based on the data you supply, and runs the query. You can either pass an array or an object to the function. Here is an example using an array:

 

 

删除数据

$this->db->delete();

生成并执行一条DELETE(删除)语句。

$this->db->empty_table();

生成并执行一条DELETE(删除)语句。

$this->db->truncate();

生成并执行一条TRUNCATE(截断)语句。

 

链式方法

链式方法允许你以连接多个函数的方式简化你的语法。考虑一下这个范例:

$this->db->select('title')->from('mytable')->where('id', $id)->limit(10, 20); 
$query = $this->db->get();

说明链式方法只能在PHP 5下面运行。

 

查询

$this->db->query();

要提交一个查询,用以下函数:

$this->db->query('YOUR QUERY HERE');

query() 函数以object(对象 -->

  • 暂无任何回答