国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > 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);      

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 丰顺县| 科技| 霍城县| 五家渠市| 长葛市| 旬阳县| 海伦市| 连江县| 寻乌县| 靖江市| 鹤壁市| 侯马市| 安多县| 安达市| 萨迦县| 徐汇区| 云梦县| 卢氏县| 珠海市| 西昌市| 香格里拉县| 封开县| 昌乐县| 安徽省| 壶关县| 青田县| 临泽县| 长治县| 民和| 杭州市| 共和县| 田东县| 宝清县| 武清区| 通山县| 梁山县| 荔浦县| 柞水县| 蓬溪县| 康马县| 贞丰县|