CodeIgniter (CI)框架中的数据库查询汇总

本文详细介绍了CodeIgniter (CI) 框架中的数据库查询,包括查询结果集、条件查询、去重、排序、分页、计数、插入记录、更新和删除等常见操作,提供了丰富的示例代码供参考。
摘要由CSDN通过智能技术生成

 由于poscms是基于CI框架的,所以CI中常见的数据库查询语句是该熟悉一点,所以在这里做个记录。

 

//一般查询
$this->db->select('name,grade')->where('sex','男')->limit(10,10)->get('tableName')->result();

一、查询结果集

->result();---------------------------------------------------返回object数组(多条记录)

->result_array();-------------------------------------------返回二维数组

->row();------------------------------------------------------返回一个对象(一条记录)

->row_array();----------------------------------------------返回一维数组

$this->db->insert_id();------------------------------------上一条插入的数据记录的id值(数据插到主表后,立即插到附表的话,id关联的时候回用到)

二、条件查询

->where('name','Jack');-----------------------------------条件是姓名为Jack

$ids = [1,2,3,4,5]

->where_in('id',[Math Processing Error]ids);−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−ids是一个数组

->where_not_in('id',$ids);--------------------------------与上对立

$array = array('name !=' => $name, 'id <' => $id, 'date >' => $date);

->where($array);-------------------------------------------根据多个条件来筛选

$where = "name='Joe' AND status='boss' OR status='active'";

->where($where);------------------------------------------根据自定义的sql模式的where语句进行筛选

->like('title', 'match', 'before');---------------------------模糊匹配,第三个参数可选,不选的话就是下面第三种情况,%match

->like('title', 'match', 'after');-----------------------------模糊匹配,match%

->like('title', 'match', 'both');-----------------------------模糊匹配,%match%

->not_like('title', 'match', 'both')------------------------模糊匹配,与上对立

$array = array('title' => $match, 'page1' => $match, 'page2' => $match);

->like([Math Processing Error]array)−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−模糊匹配关联数组,match%

三、distinct去重

->select('username,grade')->distinct();---------------根据用户名和成绩去重,只有用户名和成绩都相同才会被去重

四、排序

->order_by('title DESC, name ASC');-----------------title降序name升序

->order_by('name','RANDOM');------------------------随机排序,第一个参数无实际意义,但是要写,随机嘛,谈不上根据哪个字段随机了

五、分页

->limit(10);---------------------------------------------------未设置偏移量,那么默认偏移量为0,即从0开始选择,选出10条数据

->limit(10,10);-----------------------------------------------设置了偏移量,从10开始,选出10条数据,即11-20条记录

六、计数

->count_all('tableName')---------------------------------查询数据表中总的记录数

->where($where)->from('tableName')->count_all_results();查询符合当前条件的记录的数目,注意用from而不是get

->where($where)->count_all_results('tableName');效果同上

七、插入记录

$data = array(

  'title' => 'My title',

  'name'=>'My name',

);

->insert('tableName',$data);-----------------------------往表中插入一条数据

$data = array(

      array(

        'title' => 'My title',

        'name'=>'My name',

      ),

      array(

        't

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值