本文實例講述了thinkPHP資料庫增刪改查操作方法。分享給大家供大家參考,具體如下:
thinkphp對資料庫增刪改查進行了封裝操作,使得使用更加方便,但是不一定靈活。
可以用封裝的用,要寫sql,可以執行sql。
1.原始的
$Model = new Model(); // 实例化一个model对象 没有对应任何数据表 $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);
另一種寫法,_可以寫成大寫,它會自動轉換到_
$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
確實挺方便的,但是方便之餘,別忘了原始的sql,原汁原味的sql,才最有意思。
5.find()
$model = M('WxuserCollection'); $data = array('user_id' = >$user_id, 'store_id' = >$store_id, 'good_id' = >$good_id, 'addtime' = >$addtime); $model - >data($data) - >add();
find取得一條數據,find(1)取得id為1的數據,find(2)取得id為2的數據。最後一個是取得條件為where的中的第一個資料。
5.select()
$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語句的順序了,隨心所欲呼叫函數就可以了。
6.delete()
$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();
$model = M('WxuserCollection'); $res = $model - >where('good_id=1105 AND store_id = 1 AND user_id = 20') - >field('id,good_id as good') - >select();
依照條件刪除操作
7.field()
$model = M('WxuserCollection'); $res = $model - >where('id=1') - >delete(); // 成功返回1 失败返回0
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();
$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();
$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();
$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
$User = M("User"); // 实例化User对象 // 获取ID为3的用户的昵称 $nickname = $User->where('id=3')->getField('nickname');
$User = M("User"); // 实例化User对象 // 获取status为1的用户的昵称列表 $nickname = $User->where('status=1')->getField('nickname',true);
取得某一值字串結果的nick。也就是說,即使有滿足條件的多個字段,也只會傳回一個結果。
$nickname = $User->where('status=1')->getField('nickname',8);
$User = M("User"); // 实例化User对象 // 获取status为1的用户的昵称列表 $nickname = $User->where('status=1')->getField('id,nickname');
$result = $User->where('status=1')->getField('id,account,nickname');
$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(); // 调试sql语句用 $count = $this->collectModel->table("sh_wxuser_collection a")->where($where)->count(); // 获取总的记录数
field('b.name', 'b.price', 'b.oprice', 'b.logoimg', 'a.goods_id') // 错误
這裡由於結合了兩張表,所以用到了table方法,重新定義表名,相應的條件和參數都要加上前綴。 a. 或b.
其中field字段要么是一個字串,要么是數組。
echo M()->getLastSql();
我之前就這麼寫,問題大大的。
使用框架,就不能靈活的寫sql了。不過對sql有一個深刻的認識,也有利於靈活的使用好框架。
用於調試sql語句的方法。
rrreee希望本文所述對大家基於ThinkPHP框架的PHP程式設計有所幫助。 更多thinkPHP資料庫增刪改查操作方法實例詳解相關文章請關注PHP中文網!
關於thinkphp如何寫自己函數和類,放在什麼位置,怎麼調用,求教thinkPHP簡單調用函數與類別庫方法的範例程式碼🎜框架使用PH🎜thinkPHP簡單呼叫函數與類別庫方法的範例程式碼🎜 addAll()批次插入資料的方法分享🎜🎜