首页 > 开发 > ThinkPHP > 正文

ThinkPHP中的查询语言

2024-09-09 15:20:05
字体:
来源:转载
供稿:网友

一、普通查询

在查询带入where条件等,最少有三种形式

1、字符串形式

'id>5 and id<9'

2、数组形式

  1. $user=M('user'); 
  2. $data['username']='liwenkai'
  3. $list=$user->where(array('username'=>'liwenkai'))->select(); 
  4. $list=$user->where($data)->select(); 

3、对象形式

  1. $user=M('user'); 
  2. $a=new stdClass(); 
  3. $a->username='liwenkai'
  4. $list=$user->where($a)->select(); 

4、查询表达式

EQ    等于

NEQ   不等于

GT    大于

EGT   大于等于

LT    小于

ELT   小于等于

LIKE    等价与sql中的like

[NOT] BETWEEN   查询区间

[NOT] IN   查询集合

EXP    指使用标准SQL语句,实现更加复杂的情况

  1. $data['字段名']=array('是表达式','查询条件'); 
  2. $data['liwenkai']='liwenkai';实际上是指$data['liwenkai']=array('eq','liwenkai'); 
  3.  
  4. $data['username']=array('like','peng%'); 
  5. $list=$user->where($data)->select(); 

二、区间查询

  1. $user=M('user'); 
  2. $data['id']=array(array('gt',20),array('lt',23),'and'); 
  3. $list=$user->where($data)->select(); 
  4. dump($list); 
  5. $data['username']=array(array('like','p%'),array('like','h%'),'or'); 

三、组合查询

  1. $user=M('user'); 
  2. $data['username']='pengyanjie'
  3. $data['password']=array('eq','pengyanjie'); 
  4. $data['id']=array('lt',30); 
  5. $data['_logic']='or'
  6. $list=$user->where($data)->select(); 
  7. dump($list); 

四、复合查询

  1. $user=M('user'); 
  2. $data['username']=array('eq','pengyanjie'); 
  3. $data['password']=array('like','p%'); 
  4. $data['_logic']='or'
  5. $where['_complex']=$where
  6. $where['id']=array('lt',30); 
  7. $list=$user->where($data)->select(); 
  8. dump($list); 
  9. //相当于(id<30)and ( (username=pengyanjie) or (password like p%) ) 

五、统计查询

  1. echo $user->count(); 
  2. echo '<br>'
  3. echo $user->max('id'); 
  4. echo '<br>'
  5. echo $user->where('id<30')->min('id'); 
  6. echo '<br>'
  7. echo $user->avg('id'); 
  8. echo '<br>'
  9. echo $user->sum('id'); 

六、定位查询

  1. $user=new AdvModel('user');//实例化高级模型AdvModel 
  2.          //$user=M('user','CommonModel');//或者将AdvModel用CommonModel来继承 
  3.          $list=$user->order('id desc')->getN(2);//返回结果中的第三条 
  4.          dump($list); 
  5.  
  6.          $list=$user->order('id desc')->last();//返回最后一条 
  7.          $list=$user->order('id desc')->first();//返回第一条 

七、SQL查询

excute()主要用于更新和写入

  1. $Model = new Model()  //  实例化一个 model 对象   没有对应任何数据表 
  2.  
  3. $Model->execute( "update think_user set name='thinkPHP' where status=1" ); 

query()主要用于查询

  1. $user=M(); 
  2. $list=$user->query('select * from aoli_user order by id desc'); 
  3. dump($list);  

八、动态查询

  1. $user=M('user'); 
  2. $list=$user->getByusername('pengyanjie'); 
  3. $list=$user->getByusername('pengyanjie'); 
  4. dump($list); 
  5. $user=new AdvModel('user'); 
  6. $list=$user->top5();//前5条 
  7. dump($list); 

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选