首页 > PHP资讯 > PHP培训技术 > ThinkPHP查询语言

ThinkPHP查询语言

PHP培训技术

一、普通查询

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

  1. EQ  = 
  2. NEQ != 
  3. GT  > 
  4. EGT >
  5. LT  <div> 
  6. ELT <
  7. LIKE  like 
  8. [NOT]BETWEEN  [not]between 
  9. [not]in 

推荐使用数组形式查询

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、查询表达式

  1. EQ              等于 
  2.      NEQ             不等于 
  3.      GT              大于 
  4.      EGT             大于等于 
  5.      LT              小于 
  6.      ELT             小于等于 
  7.      LIKE            等价与sql中的like 
  8.      [NOT] BETWEEN   查询区间 
  9.      [NOT] IN        查询集合 
  10.      EXP             指使用标准SQL语句,实现更加复杂的情况 
  11.  
  12.      $data['字段名']=array('是表达式','查询条件'); 
  13.      $data['liwenkai']='liwenkai';实际上是指$data['liwenkai']=array('eq','liwenkai'); 
  14.      
  15.      $data['username']=array('like','peng%'); 
  16.      $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 '
    '
  3. echo $user->max('id'); 
  4. echo '
    '
  5. echo $user->where('id<30')->min('id'); 
  6. echo '
    '
  7. echo $user->avg('id'); 
  8. echo '
    '
  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. $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.  
  6. $user=new AdvModel('user'); 
  7. $list=$user->top5();//前5条 
  8. dump($list); 

PHP培训技术

本文由欣才IT学院整理发布,未经许可,禁止转载。
支持32不支持0