首页 > 开发 > ThinkPHP > 正文

CURD和关联操作

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

1、简单查询

  1. $user=M('user'); 
  2. //查询一条信息,返回一维数组 
  3. $list=$user->find(); 
  4. //查询所有信息,返回二维数组select或者findAll() 
  5. $list=$user->select(); 

2、查询中的连贯操作

(1)、where方法

  1. $User->where( 'status=1' )->order( 'create_time' )->limit(10)->select(); 
  2.    $User->select(array'order'=>'create_time''where'=>'status=1''limit'=>'10' )); 
  3.    $User->where( 'id=1' )->field( 'id,name,email' )->find();  
  4.    $User->where( 'status=1 and id=1' )->delete(); 
  5.    $list=$user->where('id>1')->limit('5')->order('id desc')->field('id,username')->select();  

(2)、跨表查询$user->table()

  1. $list=$user->table('aoli_user u,aoli_test t')->where('u.id=t.id')->select();  

(3)、$user->data() data方法是可以被替代的,主要在save,add,delete操作的时候使用,保存数据用的

  1. $Model->data($data)->add(); 
  2. $Model->data($data)->where( 'id=3' )->save(); 

Data 方法的参数支持对象和数组,如果是对象会自动转换成数组,如果不定义 data 方法赋值,也可以使用 create 方法或者手动给数据对象赋值的方式.

(4)、$user->field()

指定查询哪些字段字段,参数可以是字符串field('user.id as uid,m.id as mid '),也可以是数组field(array('user.id'=>'uid','m.id'=>'mid'))

(5)、$user->order()

参数也是既可以是字符串order('id desc')也可以是数组order(array('id'=>'desc','username'))

  1. $Model->field( 'id,nickname as name' )->select(); 
  2. $Model->field(array'id','nickname'=>'name' ))->select(); 

(6)、limit()

有两个参数,第一个指起始位置,第二个参数指定查询多少条.

limit('8')  从第1条开始,查8条

limit('3,8')  从第3条开始,查8条

(7)、page()查询分页

(8)、group()分组

$user->group('')->select()

(9)、having方法,主要用于二次过滤。

(10)、join关联查询,常用的有内关联,左关联,右关联,默认为左关联

(11)、distinct 唯一性过滤

select distinct id ,username from ..

过滤掉重复过滤

$user->distinct(true)->select();

(12)、relation方法 关联模型

(13)、lock 查询锁 lock(true)

3、更新数据 save()

  1. $user=M('user'); 
  2. $data['password']='aaaa'
  3. $list=$user->where('id=1')->save($data); 
  4. //或者 
  5. $user=M('user'); 
  6. $data['password']='aaaa'
  7. $data['id']='4'
  8. $list=$user->save($data); 
  9. //或者 
  10. $user=M('user'); 
  11. $data['password']='aaaa'
  12. $data['id']='4'
  13. $list=$user->data($data)->save(); 

create来更新数据

create.html:

  1. <form action="__URL__/addit" method="post"> 
  2.       <input type="text" name="id" /> 
  3.       <input type="text" name="username" /> 
  4.       <input type="password" name="password" /> 
  5.       <input name="id" type="hidden" value="25" /> 
  6.       <input type="submit" name="sub" value="提交" /> 
  7. </form> 

UserAction.class.php

  1. function create(){ 
  2.         $this->display(); 
  3.      } 
  4.       
  5.      function addit(){ 
  6.          $user=M('user'); 
  7.          if($vo=$user->create()){ 
  8.              //$user->password=md5($user->password); 
  9.              if($user->save()){ 
  10.                  $this->success('更新成功'); 
  11.              }else
  12.                  $this->error('更新失败');     
  13.              } 
  14.          } 
  15.      } 

$vo为影响的行数,即更新了多少行,其它方法诸如setInc(通常是数字的字段来进行操作),第一个写字段,第二个写条件,第三个写需要增加整数:

$list=$user->setInc('price','id=1',3);//表示price的字段加3

setDec就是进行减的操作

$list=$user->setDec('price','id=1',3);//表示price的字段减3

setField单条记录定向修改

$user->where('id=1')->setField(array('username','password'),array('google','baidu'));

4、添加数据 add()

  1. $user=M('user'); 
  2. $data['password']='aaaa'
  3. $list=$user->data($data)->add();   

$list为插入后的主键值,或者用createg来添加:

  1. function addit(){ 
  2.      $user=M('user'); 
  3.      $vo=$user->create(); 
  4.      $user->add();         
  5.  } 

表单post过来的值经过create方法以数组的形式压缩到了$vo中

5、删除数据 delete()

  1. function del(){ 
  2.    $user=M('user'); 
  3.    $list=$user->delete(25); 
  4.    dump($list);      
  5. //或者 
  6. function del(){ 
  7.    $user=M('user'); 
  8.    $list=$user->where('id>5')->delete(); 
  9.    dump($list);      

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

图片精选