首頁  >  文章  >  php框架  >  一文詳解Thinkphp5中怎麼增刪改查資料庫

一文詳解Thinkphp5中怎麼增刪改查資料庫

青灯夜游
青灯夜游轉載
2022-02-10 18:22:513411瀏覽

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模型

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

三、呼叫model模型的方法

//导入定义的数据模型类
use \app\index\model\User;

//方法一:
$res = User::get(1);

//方法二:
$user = new User;
$res = $user::get(1);	

//方法三:
use think\Loader;
$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

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

十、model模型的修改器

十一、model模型的自动完成

auto       新增及更新的时候,自动完成的属性数组
insert     仅新增的时候,自动完成的属性数组
update   仅更新的时候,自动完成的属性数组

1、自动完成 

2、添加数据时,自动完成 

3、更新数据时,自动完成:

十二、自动完成时间戳

在数据库配置文件database.php中,有下列这项配置:

//自动写入时间戳字段
'auto_timestamp'  => false,
//如果开启(设置为true),则会自动完成所有表的时间戳,但是不建议这样,只在需要的地方设置更安全。

例如对用户表的时间戳自动完成,就在User的model中设置:

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、开启软删除

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视频教程

以上是一文詳解Thinkphp5中怎麼增刪改查資料庫的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:juejin.cn。如有侵權,請聯絡admin@php.cn刪除