亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

thinkPHP數(shù)據(jù)庫增刪改查操作方法實例詳解

 更新時間:2016年12月06日 09:43:21   作者:牛逼的霍嘯林  
這篇文章主要介紹了thinkPHP數(shù)據(jù)庫增刪改查操作方法,結(jié)合實例形式詳細分析了thinkPHP常用數(shù)據(jù)庫操作函數(shù)與相關(guān)使用技巧,需要的朋友可以參考下

本文實例講述了thinkPHP數(shù)據(jù)庫增刪改查操作方法。分享給大家供大家參考,具體如下:

thinkphp對數(shù)據(jù)庫增刪改查進行了封裝操作,使得使用更加方便,但是不一定靈活。

可以用封裝的用,需要寫sql,可以執(zhí)行sql。

1.原始的

$Model = new Model(); // 實例化一個model對象 沒有對應(yīng)任何數(shù)據(jù)表
$insert_sql = "INSERT INTO sh_wxuser_collection (user_id,store_id,good_id,addtime) VALUES('".$user_id."','".$store_id."','".$good_id."','".$addtime."');";
$Model - >query($insert_sql);

2.針對表實例化的,這里的表原名是sh_wxuser_collection。sh是前綴。

$model = M('wxuser_collection'); //自動省去sh
$insert_sql = "INSERT INTO __TABLE__ (user_id,store_id,good_id,addtime) VALUES('".$user_id."','".$store_id."','".$good_id."','".$addtime."');";
$model - >query($insert_sql);

另一種寫法,_可以寫成大寫,它會自動轉(zhuǎn)化成_

$model = M('WxuserCollection'); //自動省去sh
$insert_sql = "INSERT INTO __TABLE__ (user_id,store_id,good_id,addtime) VALUES('".$user_id."','".$store_id."','".$good_id."','".$addtime."');";
$model - >query($insert_sql);

3. 封裝的add語句

$model = M('WxuserCollection');
$data = array('user_id' = >$user_id, 'store_id' = >$store_id, 'good_id' = >$good_id, 'addtime' = >$addtime);
$model - >data($data) - >add();

4.封裝的修改edit語句

$model = M('WxuserCollection');
$data = array('user_id' = >$user_id, 'store_id' = >$store_id, 'good_id' = >$good_id, 'addtime' = >$addtime);
$model - >data($data) - >where('id=3') - >save();

確實挺方便的,但是方便之余,別忘了原始的sql,原汁原味的sql,才最有意思。

5.find()

$model = M('WxuserCollection');
$res1 = $model - >find(1);
$res2 = $model - >find(2);
$res3 = $model - >where('good_id=1105 AND store_id = 1 AND user_id = 20') - >find();

find獲取一條數(shù)據(jù),find(1)獲取id為1的數(shù)據(jù),find(2)獲取id為2的數(shù)據(jù)。最后一個是獲取條件為where的中的第一條數(shù)據(jù)。

5.select()

$model = M('WxuserCollection');
$res = $model - >where('good_id=1105 AND store_id = 1 AND user_id = 20') - >field('id,good_id as good') - >select();

獲取所有數(shù)據(jù)。這里的好處就是,不用考慮sql語句的順序了,隨心所欲調(diào)用函數(shù)就可以了。

6.delete()

$model = M('WxuserCollection');
$res = $model - >where('id=1') - >delete(); // 成功返回1 失敗返回0

根據(jù)條件進行刪除操作

7.field()

$model = M('WxuserCollection');
$res = $model - >field('id,good_id as good') - >select();
$res = $model - >field(array('id', 'good_id' = >'good')) - >select();
$res = $model - >field('id', true) - >select();

字符串,數(shù)組兩種方式,第三個是表示獲取處理id之外的所有字段。

8.order()

$model = M('WxuserCollection');
$res = $model - >order('id desc') - >select();
$res = $model - >order('id asc') - >select();
$res = $model - >order(array('id' = >'desc')) - >select();
$res = $model - >order(array('id')) - >select();

字符串,數(shù)組兩種方式,默認asc。

9.join()

$Model->join(' work ON artist.id = work.artist_id')->join('card ON artist.card_id = card.id')->select();
$Model->join('RIGHT JOIN work ON artist.id = work.artist_id')->select();
$Model->join(array(' work ON artist.id = work.artist_id','card ON artist.card_id = card.id'))->select();

默認采用LEFT JOIN 方式,如果需要用其他的JOIN方式,可以改成第二種,

如果join方法的參數(shù)用數(shù)組的話,只能使用一次join方法,并且不能和字符串方式混合使用。

10.setInc()

$User = M("User"); // 實例化User對象
$User->where('id=5')->setInc('score',3); // 用戶的積分加3
$User->where('id=5')->setInc('score'); // 用戶的積分加1
$User->where('id=5')->setDec('score',5); // 用戶的積分減5
$User->where('id=5')->setDec('score'); // 用戶的積分減1

11.getField()

獲取某個字段值

$User = M("User"); // 實例化User對象
// 獲取ID為3的用戶的昵稱
$nickname = $User->where('id=3')->getField('nickname');

返回的nickname是一個字符串結(jié)果。也就是說,即使有滿足條件的多個字段,也只會返回一個結(jié)果。

獲取某個字段列

如果希望返回符合要求的字段列(多個結(jié)果),可以使用:

$User = M("User"); // 實例化User對象
// 獲取status為1的用戶的昵稱列表
$nickname = $User->where('status=1')->getField('nickname',true);

第二個參數(shù)傳入了true,返回的nickname則是一個數(shù)組,包含了所有滿足條件的昵稱列表。

如果需要限制返回結(jié)果數(shù)量,可以使用:

$nickname = $User->where('status=1')->getField('nickname',8);

獲取2個字段列表

$User = M("User"); // 實例化User對象
 // 獲取status為1的用戶的昵稱列表
$nickname = $User->where('status=1')->getField('id,nickname');

如果getField方法傳入多個字段名稱的話,默認返回一個關(guān)聯(lián)數(shù)組,以第一個字段的值為索引(所以第一個字段要盡量選擇不會重復的)。

獲取多個字段列表

$result = $User->where('status=1')->getField('id,account,nickname');

如果傳入了2個以上的字段名,則返回一個二維數(shù)組(類似select方法的返回值,區(qū)別在于索引是二維數(shù)組的鍵名是第一個字段的值)

綜合使用案例

$where = array('a.store_id' => $this->store_id, 'a.user_id' => $this->user_id);
$collects = $this->collectModel->table("sh_wxuser_collection a")->field(array('b.name','b.price','b.oprice','b.logoimg','a.goods_id'))->limit($start, $offset)->order('a.addtime DESC')->where($where)->join(' sh_goods b ON a.goods_id = b.id')->select();// 獲取當前頁的記錄
echo M()->getLastSql(); // 調(diào)試sql語句用
$count = $this->collectModel->table("sh_wxuser_collection a")->where($where)->count(); // 獲取總的記錄數(shù)

這里由于結(jié)合了兩張表,所以用到了table方法,重新定義表名,相應(yīng)的條件和參數(shù)都要加上前綴。a. 或者b.

其中field字段要么是一個字符串,要么是數(shù)組。

field('b.name', 'b.price', 'b.oprice', 'b.logoimg', 'a.goods_id') // 錯誤

我之前就這么寫,問題大大的。

使用框架,就不能靈活的寫sql了。不過對sql有一個深刻的認識,也有利于靈活的使用好框架。

用于調(diào)試sql語句的方法。

echo M()->getLastSql();

很方便。

更多關(guān)于thinkPHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《ThinkPHP入門教程》、《thinkPHP模板操作技巧總結(jié)》、《ThinkPHP常用方法總結(jié)》、《codeigniter入門教程》、《CI(CodeIgniter)框架進階教程》、《Zend FrameWork框架入門教程》、《smarty模板入門基礎(chǔ)教程》及《PHP模板技術(shù)總結(jié)》。

希望本文所述對大家基于ThinkPHP框架的PHP程序設(shè)計有所幫助。

相關(guān)文章

  • 老生常談PHP面向?qū)ο笾畼俗R映射

    老生常談PHP面向?qū)ο笾畼俗R映射

    下面小編就為大家?guī)硪黄仙U凱HP面向?qū)ο笾畼俗R映射。小編覺得挺不錯的。現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • PHP中使用curl入門教程

    PHP中使用curl入門教程

    這篇文章主要介紹了PHP中使用curl入門教程,本文講解了curl概述 、安裝curl、PHP中使用curl的步驟、一個簡單的curl代碼實例等內(nèi)容,需要的朋友可以參考下
    2015-07-07
  • PHP編程開發(fā)怎么提高編程效率 提高PHP編程技術(shù)

    PHP編程開發(fā)怎么提高編程效率 提高PHP編程技術(shù)

    這篇文章主要介紹了PHP編程開發(fā)怎么提高編程效率(牢記這20個點)的相關(guān)資料,需要的朋友可以參考下
    2015-11-11
  • thinkphp3.2實現(xiàn)上傳圖片的控制器方法

    thinkphp3.2實現(xiàn)上傳圖片的控制器方法

    這篇文章主要介紹了thinkphp3.2實現(xiàn)上傳圖片的控制器方法,結(jié)合實例形式分析了thinkPHP圖片文件上傳相關(guān)的文件類型判斷,文件路徑及相關(guān)屬性操作技巧,需要的朋友可以參考下
    2016-04-04
  • 分享PHP函數(shù)實現(xiàn)數(shù)字與文字分頁代碼

    分享PHP函數(shù)實現(xiàn)數(shù)字與文字分頁代碼

    這篇文章主要介紹了PHP函數(shù)實現(xiàn)數(shù)字與文字分頁代碼,定義分頁函數(shù)_paging,在核心函數(shù)庫包裝代碼,需要的朋友可以參考下
    2015-07-07
  • PHP命名空間(namespace)的動態(tài)訪問及使用技巧

    PHP命名空間(namespace)的動態(tài)訪問及使用技巧

    上篇文章介紹了PHP命名空間的一些術(shù)語,其解析規(guī)則,本文我們來繼續(xù)講述PHP命名空間動態(tài)訪問及使用技巧,希望能有所幫助
    2014-08-08
  • yii2中使用Active Record模式的方法

    yii2中使用Active Record模式的方法

    這篇文章主要介紹了yii2中使用Active Record模式的方法,結(jié)合實例分析了Yii2中使用Active Record模式的具體步驟與相關(guān)操作方法,需要的朋友可以參考下
    2016-01-01
  • wamp下修改mysql訪問密碼的解決方法

    wamp下修改mysql訪問密碼的解決方法

    本篇文章是對wamp下修改mysql訪問密碼的方法進行了詳細的介紹。需要的朋友參考下
    2013-05-05
  • YII框架http緩存操作示例

    YII框架http緩存操作示例

    這篇文章主要介紹了YII框架http緩存操作,結(jié)合實例形式分析了Yii框架針對http緩存的禁用、啟用、讀寫、顯示等相關(guān)操作技巧,需要的朋友可以參考下
    2019-04-04
  • laravel 實現(xiàn)用戶登錄注銷并限制功能

    laravel 實現(xiàn)用戶登錄注銷并限制功能

    今天小編就為大家分享一篇laravel 實現(xiàn)用戶登錄注銷并限制功能,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-10-10

最新評論