成人怡红院-成人怡红院视频在线观看-成人影视大全-成人影院203nnxyz-美女毛片在线看-美女免费黄

站長資訊網
最全最豐富的資訊網站

一文詳解Thinkphp5中怎么增刪改查數據庫

Thinkphp5中怎么操作數據庫,進行增刪改查?下面本篇文章就來帶大家詳細了解一下Thinkphp5中增刪改查數據庫的方法,希望對大家有所幫助!

一文詳解Thinkphp5中怎么增刪改查數據庫

thinkphp標準數據表設計:

創建時間字段:create_time

更新時間字段:update_time

刪除時間字段:delete_time

類型選int,如下圖:

一文詳解Thinkphp5中怎么增刪改查數據庫

【相關教程推薦:thinkphp框架】

一、創建model的文件夾

在application文件夾下的二級對象目錄中新建名為model的文件夾,該文件夾與對應的controller和view目錄同級,如下圖:

一文詳解Thinkphp5中怎么增刪改查數據庫

如果有多個模塊(比如前臺index,后臺admin),操作的數據庫都差不多,那么可以把model模型放到common公共模塊里,如下:

一文詳解Thinkphp5中怎么增刪改查數據庫

二、創建model模型類

1、在model目錄下創建model對象文件,一般model的名字和表名是對應的,例如:

表名 pre_user       --------------->  模型名 User.php 表名 pre_user_info  --------------->  模型名 UserInfo.php

2、定義model模型

<?php namespace appindexmodel; use thinkModel; use thinkDb;  class User extends Model{ 	/**      * 定義變量      * 1.變量名稱應與數據表中的字段名相同      * 2.此處可根據需求省略,因為如果沒有,thinkphp會自動在數據表中尋找的對應字段名      */ 	public $username; 	public $password; } ?>

3、如果數據模型定義名和表名不一致,那么就需要額外定義和聲明,如下:

<?php namespace appindexmodel; use thinkModel; use thinkDb;  class User extends Model { 	protected $table = "admin_user";//指定數據表名     protected $pk = 'id';           //指定主鍵的字段 } ?>

三、調用model模型的方法

//導入定義的數據模型類 use appindexmodelUser;  //方法一: $res = User::get(1);  //方法二: $user = new User; $res = $user::get(1);	  //方法三: use thinkLoader; $user = Loader::model("User"); $res = $user::get(1);  //方法四: $user = model("User");        $res = $user::get(1);

四、查詢操作

get 獲取一條記錄

$res = User::get(1);

all 獲取多條記錄

1、不傳參

$result = User::all(); //查詢出所有記錄

2、參數為n,n為正整數

$result = User::all(1); //查詢出id為1的記錄

3、參數為'n1, n2, n3…'

$result = User::all('7, 8, 9, 10'); //查詢出id為7、8、9、10的4條記錄

4、參數為[n1, n2, n3…]

$result = User::all([7, 8, 9, 10]); //查詢出id為7、8、9、10的4條記錄

find 查詢某一條

 $res = User::where('id','1')->field('name')->find();

不等于

->where('id','neq',1)

select 多條查詢

$res = User::where('id','1')->field('name')->limit(2)->order('id DESC')->select();

value 按字段查詢一條

$res = User::where('id','1')->value('name');

將結果轉換成數組

$res = $res->toArray();

查詢數目

//查詢總條數 $res = User::count(); //按條件統計條數 $res = User::where('id','>',3)->count();

whereTime() 時間條件查詢

1、獲取今天的信息

db('table')->whereTime('c_time', 'today')->select(); //也可以簡化為下面方式 db('table')->whereTime('c_time', 'd')->select();

2、獲取昨天的信息

db('table')->whereTime('c_time', 'yesterday')->select();

3、獲取本周的信息

db('table')->whereTime('c_time', 'week')->select();    //也可以簡化為下面方式 db('table')->whereTime('c_time', 'w')->select();

4、獲取本月的信息

db('table')->whereTime('c_time', 'month')->select();    //也可以簡化為下面方式 db('table')->whereTime('c_time', 'm')->select();

5、獲取上月的信息

db('table')->whereTime('c_time','last month')->select();

6、獲取今年的信息

db('table')->whereTime('c_time', 'year')->select();     //也可以簡化為下面方式 db('table')->whereTime('c_time', 'y')->select();

7、獲取去年的信息

db('table')->whereTime('c_time','last year')->select();

8、日期區間查詢

//根據時間戳查詢今天到后天 db('table')->whereTime('time', 'between', [strtotime(date('Y-m-d')), strtotime(date('Y-m-d', strtotime('+2 day')))])->select(); 根據日期查詢今天到后天 db('table')->whereTime('time', 'between', ['2020-3-28', '2020-3-30'])->select();

五、添加操作

1、使用create()方法添加

$res = User::create([      'name'      => '安陽',      'age'       => 23,      'sex'       => 1,      'password'  => '123456'  ]);

2、添加數據,并返回添加的主鍵

$uid=UserModel::create([      'name'      => '安陽',      'age'       => 23,      'sex'       => 1,      'password'  => '123456'  ])->id;

也可以使用DB類的insertGetId方法,如下:

$uid = User::insertGetId([      'name'      => '安陽',      'age'       => 23,      'sex'       => 1,      'password'  => '123456'  ]);

3、實例化方式添加

 $user = new User;  $user->name =  '安陽';  $user->age =  23;  $user->save();

4、實例化方式過濾插入字段,返回插入行數

 $user = new User;  $data = [      'name' => '安陽',      'age' => 23,      'email' => '123456@qq.com'  ];  //只有name和age字段會寫入  $res = $user->allowField(['name', 'age'])->save($data);

5、模型使用allowField()過濾非數據表字段的數據

//定義模型對象,并傳入post數據 $user = new User($_POST); //過濾post數組中的非數據表字段數據 $user->allowField(true)->save();

6、模型使用allowField()指定某些字段寫入

$user = new User; // post數組中只有name和email字段會寫入 $user->allowField(['name','email'])->save($_POST, ['id' => 1]);

7、批量添加使用saveAll()

user = new User; $list = [     ['name'=>'安陽','email'=>'thinkphp@qq.com'],     ['name'=>'小柒','email'=>'12345678@qq.com']  ]; $user->saveAll($list);

也可以使用DB類的insertAll()方法,返回添加成功的條數

$res = User::insertAll([      'name'      => '安陽',      'age'       => 23,      'sex'       => 1,      'password'  => '123456'  ]);

補充,過濾字段的其他方法:

1、在DB操作中,可以使用 strict 關閉字段嚴格檢查

Db::name(‘user’)->strict(false)->insert($data);

2、使用php的 unset() 方法銷毀變量

unset($data[‘file’]);

6、saveAll添加多條數據,返回對象列表

 $user = new User;  $data = [      [          'name' => '安陽',          'age' => 20,          'email' => '123456@qq.com'      ],      [          'name' => '小柒',          'age' => 25,          'email' => 'ap555@qq.com'      ]  ];  $res = $user->allowField(['name', 'age'])->saveAll($data);

六、更新操作

1、update 返回影響行數

 $res = User::where(['id'=>1])->update(['name'=>'安陽']);

2、setField 單獨更新某個字段

User::where('id',1)->setField('name','安陽');

3、setInc

//setInc('money',10)表示將money字段加上10 User::where(['id'=>1])->setInc('money', 10);

4、setDec

//setDec('money',10)表示將money字段減去10 User::where(['id'=>1])->setDec('money', 10);

5、批量更新,要求數據中含有主鍵,返回更新對象列表

$user = new User; $res = $user->saveAll([      ['id'=>1, 'name' => '安陽'],      ['id'=>2, 'name' => '小柒']  ]);

七、刪除操作

1、傳入主鍵,返回影響行數

$res = User::destroy(1);

2、傳入條件,返回影響行數

 $res = User::destroy(['name'=>'安陽']);

3、條件刪除 返回影響行數

 $res = User::where(['id'=>1])->delete();

八、事務

1、自動控制事務處理

Db::transaction(function(){      Db::table('order')->where(['id'=>1])->delete();  	Db::table('user')->where('id'=>1)->setInc('money',10);	 });

2、手動控制事務

Db::startTrans();//啟動事務 try {     Order::where(['id'=>1])->delete(); 	User::where('id'=>1)->setInc('money',10); 	Db::commit();//提交事務 } catch (Exception $e) { 	Db::rollback();	//回滾 }

九、model模型的獲取器

讀取器的命名規范是:->get + 屬性名的駝峰命名 + Attr

<?php namespace appindexmodel; use thinkModel; class User extends Model {		         //獲取器:將性別的012修改為男、女、未知 返回 	public function getSexAttr($val) 	{ 		switch ($val) {             case 1:                 return '男';             case 2:                 return '女';             default:             return '未知'; 		} 	}    //獲取器:格式化時間戳后返回     public function getUpdateTimeAttr($val){         if(!empty($val)){ 			//如果是時間戳,就格式化 			if(!strtotime($val)) { 				return date('Y-m-d H:i:s',$val); 			}else{ 				return $val; 			}         }else{ 			return ''; 		}     } }

補充說明:strtotime()將任何英文文本的日期時間描述解析為Unix 時間戳,成功則返回時間戳,否則返回 FALSE(在 PHP 5.1.0之前本函數在失敗時返回 -1)

十、model模型的修改器

<?php namespace appindexmodel; use thinkModel; class User extends Model { 	//修改器 	public function setTimeAttr() 	{         return time(); 	}     /** 修改器:對密碼字段加密之后存儲      * $val  第一個參數是密碼      * $data 第二個參數是添加的數據(可選)      */     public function setPasswordAttr($val,$data){         if($val === '') {             return $val;         }else{             return md5($val.$data['email']);         }     } }

十一、model模型的自動完成

auto 新增及更新的時候,自動完成的屬性數組
insert 僅新增的時候,自動完成的屬性數組
update 僅更新的時候,自動完成的屬性數組

1、自動完成

<?php namespace appindexmodel; use thinkModel; class User extends Model { 	//添加和修改時,都會自動完成的字段     protected $auto = ['addtime'];      public function setAddtimeAttr(){         return time();     } }

2、添加數據時,自動完成

<?php namespace appindexmodel; use thinkModel; class User extends Model { 	// 新增 自動完成     protected $insert = ['addtime'];      public function setAddtimeAttr(){         return time();     } }

3、更新數據時,自動完成:

<?php namespace appindexmodel; use thinkModel; class User extends Model { 	// 更新 自動完成     protected $update = ['addtime'];      public function setAddtimeAttr(){         return time();     } }

十二、自動完成時間戳

在數據庫配置文件database.php中,有下列這項配置:

//自動寫入時間戳字段 'auto_timestamp'  => false, //如果開啟(設置為true),則會自動完成所有表的時間戳,但是不建議這樣,只在需要的地方設置更安全。

例如對用戶表的時間戳自動完成,就在User的model中設置:

<?php namespace appindexmodel; use thinkModel;  class User extends Model{     //開啟自動完成時間戳功能     protected $autoWriteTimestamp = true;     //開啟后,     //添加數據時,默認自動完成的字段是:create_time和update_time     //修改數據時,默認自動完成的字段是:update_time          //如果數據表里不是這兩個字段,則會報錯。需要進行如下修改:     protected $createTime = 'addtime';//修改默認的添加時間字段     protected $updateTime = 'updtime';//修改默認的修改時間字段     protected $updateTime = false;//當不需要這個字段時設置為false }

Thinkphp更新時,自動更新update_time字段時間戳的方法:

1、使用update

User::update(['name'=>'安陽'],['id'=>1]);

Thinkphp中update方法的源代碼如下:

/**     * 更新數據     * @access public     * @param array      $data  數據數組     * @param array      $where 更新條件     * @param array|true $field 允許字段     * @return $this     */    public static function update($data = [], $where = [], $field = null)    {        $model = new static();        if (!empty($field)) {            $model->allowField($field);        }        $result = $model->isUpdate(true)->save($data, $where);        return $model;    }

2、使用save

$user=new User; $user->isUpdate(true)->save(['name'=>'安陽'],['id'=>1]);

十三、軟刪除

什么是軟刪除?

當刪除某些記錄時,有時我們需要假刪除,只通過修改某個字段狀態來標記該記錄已刪除,但實際上,數據庫中還是存在這些記錄的。假刪除的應用場景還是比較多的,例如支付寶的收款記錄,我們在APP上刪除后,就不會再顯示出來,你是不是以為真的刪掉了,不會再留下任何痕跡?非也,非也,刪除支付寶收款記錄只是軟刪除,在支付寶的數據庫中,實際上還保留有這些收款記錄,如果你的收款涉嫌違規或者觸犯法律,警方還是能通過支付寶的網警后臺查看到的。

1、開啟軟刪除

<?php namespace appindexmodel; use thinkModel; use traitsmodelSoftDelete;//引入軟刪除的類  class Order extends Model{     //使用軟刪除     //刪除時,默認更新的字段是delete_time     use SoftDelete;     //如果數據表里不是delete_time這個字段,則會報錯。需要進行如下修改:     protected $deleteTime = 'deltime'; }

2、 控制器里軟刪除,返回影響的行數

 $res = Order::destroy(1);

執行刪除后,就會更新delete_time字段,如果update_time字段也開啟了自動完成,也會更新update_time字段。

3、如果開啟了軟刪除,需要真正地刪除數據,而不做軟刪除,用下面的方法

//destory()第二個參數傳遞true $res = Order::destroy(1,true);  //delete()參數傳遞true $orderData = Order::get(1); $orderData ->delete(true);

4、查詢已軟刪除的數據

$res = Order::withTrashed(true)->find(1);

5、查詢僅包含已軟刪除的數據

$res = Order::onlyTrashed()->select();

推薦學習:《PHP視頻教程》

贊(0)
分享到: 更多 (0)
?
網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
ASS年轻少妇BBWPIC精品| 把腿张开老子臊烂你妙妙| 2021av在线视频| YW尤物AV无码| 国产AⅤ无码旗袍丝袜美腿| 国产九九久久99精品影院| 极品少妇流白浆草莓视频| 久久老司机精品网站福利| 嫩草伊人久久精品少妇AV| 人人爽人人爽人人片AV东京热| 天天躁日日躁狠狠躁欧美老妇小说| 先锋中文字幕在线资源| 亚洲中文字幕无码久久综合网| 696969大但人文艺术来源| 抽插丰满内射高潮视频| 国产在线无码精品无码| 巨胸美乳无码人妻在线| 人妻丰满熟妇无码区免费| 无码人妻丰满熟妇奶水区码| 亚洲日韩AV无码一区二区三区人| 99国产精品国产精品九九| 高潮好爽视频在线观看| 娇妻被朋友玩得呻吟在线电影| 蜜桃精品欧美一区二区三区| 色88久久久久高潮综合影院| 亚洲AV无码国产在丝袜线观看| 制服丝袜长腿无码专区第一页| 成人片黄网站色大片免费观看CN | 国产乱码字幕精品高清AV| 久久精品熟女亚洲AV麻豆网站 | 午夜欧美精品久久久久久久| 野花韩国日本高清免费5| めんたいさんでぃふぇんすっ甘雨| 国产精品偷窥老熟女高潮| 久久夜色精品国产噜噜| 少妇扒开腿让我爽了一夜| 亚洲精品乱码久久久久久V| VIDEOSSEX变态狂另类| 国产在线拍揄自揄拍免费下载| 蜜臀AV在线播放一区二区三区| 视频一区二区三区在线观看| 亚洲最大天堂无码精品区| 成人中文乱幕日产无线码 | 亚洲欧美日韩国产精品一区 | 色妺妺AⅤ爽爽影院偷拍| 亚洲欧美日韩中文二区| 爆乳JUFD汗だく肉感| 娇妻宾馆被三根粗大的夹击| 青青人亚洲AV永久无码精品无| 亚洲AV无码一区二区三区网站| 97婷婷狠狠成为人免费视频| 国产亚洲欧美精品一区| 欧美性色欧美A在线播放| 亚洲VA欧美VA国产VA综合| CHINESE国产老熟女| 极品白嫩的小少妇| 日本老肥婆BBBWBBBWZR| 亚洲中文字幕永久在线不卡| 国产VA免费精品观看精品| 免费拗女网站1300部| 亚洲 精品 制服 校园 无码| CHINESE熟女老女人HD| 黄 色 视 频 在 线 免费观| 搡老女人911熟妇老熟女| 樱桃空空人妻无码内射| 国产免费无码一区二区视频| 欧美熟妇黑人ⅩXXXXX| 亚洲欧洲精品无码AV| 国产成人无码AV在线播放不卡| 男女无遮挡猛进猛出免费视频| 亚洲AV中文无码乱人伦在线视色| 成人国产三级在线观看| 老师露双奶头无遮挡挤奶视频| 无码人妻丝袜视频在线播免费| GAY男同帅哥网站在线观看| 娇妻在卧室里被领导爽电影| 熟妇高潮精品区一区二区三| 91人妻一区二区三区蜜桃精品| 国语对白露脸XXXXXX| 日韩人妻无码一区二区三区99| 中国女人熟毛茸茸A毛片| 黑人入室强丰满人妻| 铜铜铜铜铜铜铜铜好大免费| めんたいさんでぃふぇんすっ甘雨| 久久久国产精品消防器材 | 日产精品一线二线三线芒| 中文精品久久久久人妻| 精品国产AV 无码一区二区三区| 体验区试看120秒啪啪免费| HEYZO中文字幕无码| 浪潮国产AV一区二区熟女| 亚洲 欧美 卡通 另类 小说| 亚洲AV无码专区亚洲AV漫画| 成交人性成交视频| 嘼皇PORONOⅤIDEOS极| 国产熟妇XXXXXⅩ性Ⅹ交| 精品香蕉一区二区三区| 日韩AV无码成人无码免费| 亚洲AV片无码久久尤物| 亚洲精品无码永久在线观看你懂的 | 日文中字乱码一二三区别在哪 | 女儿的朋友3完有限中字木瓜| 亚洲无人区码一码二码三码的特点| 国产精品亚洲综合色区韩国| 日日摸日日碰夜夜爽亚洲| JAPANESE护士高潮SEX| 免费看的WWW哔哩哔哩| 永久不收费的视频软件APP| 8x8x熟妇一区二区三区| 国产成人AⅤ片在线观看| 久久精品噜噜噜成人AV| 三个男人让我爽了一夜| 亚洲一线产区二线产区| 啊灬啊灬啊灬快高潮了网站| 国产精品不卡AⅤ在线播放| 人与性动交ⅩXXXB| 一本色道久久88加勒比—综合 | 亚洲AV无码久久精品成人| 国产乱码字幕精品高清AV| 我把护士日出水了视频| 国产对白videos麻豆高潮| 思思RE热免费精品视频66| 高潮又爽又黄又无遮挡动态图| 三个男人躁我一个爽视频免费| 菠萝蜜视频在线观看入口| 人人爽人人爽人人爽| 别揉我奶头~嗯~啊~| 日本熟妇在线一区二区三区| 产高清在线精品一区二区三区| 日本H纯肉无遮掩3D动漫在线观| 爆乳护士HD完整版在线播放| 人善交VIDE欧美| 成人国内精品久久久久影院VR| 日本真人无遮挡啪啪免费| 城中村快餐嫖老妇对白| 少妇人妻系列1~100| 国产A国产片国产| 无码人妻精品一区二区蜜桃不卡 | 蜜桃AV麻豆AV天美AV| 18禁肉肉无遮挡无码网站| 欧美虐SM另类残忍视频| 被多男摁住灌浓精| 色欲AV浪潮AV蜜臀AⅤ| 国产精品国产精品国产专区不卡| 午夜DJ在线观看免费完整版社区| 国产一码二码三码区别| 亚洲精品WWW久久久久久| 久久精品无码一区二区三区| 中日AV乱码一区二区三区乱码 | 久久久久亚洲AV片无码V| 中国国产高清免费AV片| 强壮公的侵犯让我高潮不断| 粗大在少妇体内进进出出| 玩弄人妻少妇精品视频| 好硬好涨老师受不了了| 一受多攻同做H嗯啊巨肉| 欧美另类VIDEOSBESTS| 大乱东京道一本热大交乱| 无码人妻 在线视频| 精品久久久久中文字幕日本| 影音先锋2020色资源网| 欧美伊人久久大香线蕉综合| 公交车里抓着摇曳的手环诗情| 西瓜影院免费观看完整版电影| 精品人妻一区二区三区免费| 中文字幕久久久久人妻| 日本少妇人妻XXXXX18| 国产日产欧产精品品不卡| 亚洲中文字幕久久无码精品| 欧美人与动欧交视频| 国产成人无码精品XXXX网站| 亚洲成A人片在线观看无码3D| 另类老妇性BBWBBW| 成人网站V片免费观看| 亚洲AV片无码久久尤物| 美女扒开粉嫩尿口的照片| 别揉我奶头~嗯~啊~动漫网站| 无遮挡亲胸捏胸免费视频| 久久婷婷五月综合丁香人人爽| 迷迷糊糊挺进岳身体| 锕锕锕锕锕锕锕锕好疼小视频软件| 四虎成人精品在永久免费| 精品国产一区二区AV片| 13学生小美女洗澡裸体视频| 少妇高清一区二区免费看| 精品无码人妻一区二区三区不卡| ⅩXXX张柏芝XXXX| 无码少妇一区二区三区| 国产精品免费看久久久| 亚洲一区在线日韩在线尤物| 人妻在线一区二区| 国产真人无码作爱视频免费| 综合无码成人AⅤ视频在线观看| 少妇高潮毛片免费看| 久久精品成人免费国产片| 爆乳2把你榨干哦在线观看| 亚洲AV综合色区无码二区偷拍| 欧美乱码卡1卡2卡三卡四卡| 国内久久婷婷五月综合欲色广啪| 99精品欧美一区二区三区|