一文详解Thinkphp5中怎么增删改查数据库

thinkphp5中怎么操作数据库,进行增删改查?下面本篇文章就来带大家详细了解一下thinkphp5中增删改查数据库的方法,希望对大家有所帮助!

一文详解Thinkphp5中怎么增删改查数据库

thinkphp标准数据表设计:创建时间字段:create_time更新时间字段:update_time删除时间字段:delete_time 类型选int,如下图:

【相关教程推荐:thinkphp框架】

一、创建model的文件夹

在application文件夹下的二级对象目录中新建名为model的文件夹,该文件夹与对应的controller和view目录同级,如下图:

2.png

立即学习“PHP免费学习笔记(深入)”;

如果有多个模块(比如前台index,后台admin),操作的数据库都差不多,那么可以把model模型放到common公共模块里,如下:

3.png

二、创建model模型类

1、在model目录下创建model对象文件,一般model的名字和表名是对应的,例如:

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

 2、定义model模型


3、如果数据模型定义名和表名不一致,那么就需要额外定义和声明,如下:


三、调用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()指定某些字段写入

图改改 图改改

在线修改图片文字

图改改 455 查看详情 图改改

$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字段加上10User::where(['id'=>1])->setInc('money', 10);

4、setDec

//setDec('money',10)表示将money字段减去10User::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

<?phpnamespace 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模型的修改器

<?phpnamespace 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、自动完成 

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

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

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

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

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

十二、自动完成时间戳

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

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

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

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

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

以上就是一文详解Thinkphp5中怎么增删改查数据库的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/227588.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月3日 19:47:22
下一篇 2025年11月3日 19:48:59

相关推荐

  • ThinkPHP6数据库操作指南:增删改查搞定

    ThinkPHP6数据库操作指南:增删改查搞定 引言:在Web开发过程中,数据库操作是必不可少的一环。数据库是用于存储和管理数据的关键工具,而对数据库进行增删改查操作更是经常用到的功能。本文将介绍使用ThinkPHP6框架进行数据库操作的基本方法和技巧,并提供代码示例供读者参考。 一、连接数据库在使…

    2025年12月5日
    000
  • sql的基本操作指令 sql基础操作指令大全

    sql的基本操作指令包括:1.插入数据(insert into),2.查询数据(select),3.更新数据(update),4.删除数据(delete),5.创建表(create table),6.修改表结构(alter table),7.删除表(drop table),8.创建索引(create…

    2025年12月3日
    000
  • SQL触发器使用详解 自动化数据库操作的实现方法

    sql触发器是在数据库中自动执行响应特定事件的代码块,适用于数据完整性约束、审计跟踪、级联操作和数据验证等场景。触发器分为before和after两种类型,分别在事件发生前和发生后执行;使用new和old变量访问新旧数据;其语法结构包括触发时机、事件类型、绑定表及具体逻辑。虽然触发器具备自动化优势,…

    2025年12月1日 数据库
    000
  • laravel如何连接并操作多个数据库_Laravel多数据库连接与操作方法

    Laravel支持多数据库配置,可在config/database.php中定义多个连接,并通过.env文件管理环境变量;在模型中设置$connection属性或使用DB::connection()、on()、setConnection()方法实现连接切换;事务基于单一连接,跨库操作需自行处理一致性…

    2025年11月30日
    000
  • 使用Go语言进行MySQL数据库的数据导入的方法

    使用go语言进行mysql数据库的数据导入的方法 MySQL是当前非常流行的关系型数据库,越来越多的开发者选择使用Go语言与MySQL进行数据交互,本文将介绍如何使用Go语言进行MySQL数据库的数据导入。 确定导入的数据结构在进行数据导入之前,我们首先需要确定导入的数据结构,也就是表结构,如表字段…

    数据库 2025年11月29日
    000
  • PHP 函数中引用参数在数据库操作中的应用

    在 %ignore_a_1% 中,按引用传递参数允许数据库操作函数修改传入参数。具体实现步骤如下:在参数类型声明前加 & 符号;函数修改参数值,从而更新数据库;函数完成后,传入参数的值会更新。 PHP 函数中引用参数在数据库操作中的应用 前言 在 PHP 中,函数参数可以按值传递或按引用传递…

    2025年11月28日
    000
  • MySQL中如何进行数据的去库存和库存管理?

    %ignore_a_1%中如何进行数据的去库存和库存管理? 库存管理是企业生产经营中非常关键的一个环节,对于企业的运营和发展有着重要的影响。而MySQL作为一种常用的关系型数据库管理系统,其在库存管理方面也提供了一些强大的功能和特性。本文将介绍MySQL中如何进行数据的去库存和库存管理的方法,以及相…

    数据库 2025年11月26日
    000
  • 有哪些VSCode扩展能帮助你更好地进行数据库操作?

    推荐使用SQLTools、SQLite Viewer、PostgreSQL、MySQL和Database Client等扩展提升VSCode数据库操作效率,根据数据库类型选择合适工具并注意驱动与权限配置。 在 VSCode 中进行数据库操作时,借助合适的扩展可以大幅提升效率。以下是一些实用且广受好评…

    2025年11月24日 开发工具
    000
  • 数据插入MySQL后会返回什么信息?

    数据插入MySQL后会返回一个信息,即插入操作的结果。一般情况下,如果插入操作成功,会返回一个自动生成的唯一标识符(例如自增长的主键),如果插入操作失败,则会返回一个错误信息。在MySQL中,可以通过执行INSERT语句来插入数据,并通过编程语言的MySQL驱动程序来获取插入操作的结果。 以下是一个…

    2025年11月17日
    000
  • MySQL存储过程:高效管理数据库操作

    MySQL存储过程:高效管理数据库操作 MySQL存储过程是一种预先编译并存储在数据库服务器中的一段SQL语句集,可以被多次调用执行,方便管理和提高数据库操作效率。通过存储过程,可以减少网络传输量,减少SQL解析和编译时间,提高数据处理效率。本文将介绍MySQL存储过程的基本概念和具体代码示例,帮助…

    2025年11月15日
    100
  • Swoole开发技巧:如何处理高并发的数据库操作

    Swoole开发技巧:如何处理高并发的数据库操作,需要具体代码示例 引言:在当今互联网高速发展的时代,高并发是各个系统架构中不可避免的挑战。对于使用Swoole进行开发的开发者来说,如何处理高并发的数据库操作是一个常见的问题。本文将介绍一些Swoole开发中处理高并发数据库操作的技巧,并提供具体的代…

    2025年11月13日
    000
  • Yii框架中的ORM:简化数据库操作

    yii框架是一款快速、高效、安全的php开发框架,依托于丰富的工具和组件,yii框架可以帮助开发者更轻松地构建高质量的web应用程序。其中,orm(对象关系映射)是yii框架其中之一的特点。这篇文章将简单介绍yii框架中的orm,并说明其如何简化数据库操作。 一、什么是ORMORM是指对象关系映射,…

    2025年11月10日
    000
  • 如何使用 PHP 更新 MySQL 表中的数据?

    要更新 mysql 表中的数据,可以使用 mysqli 或 pdo 方法。mysqli:建立 mysqli 连接准备 sql 更新查询执行更新查询pdo:建立 pdo 连接准备 sql 更新查询(使用预处理语句)绑定参数(如果有)执行更新查询 如何使用 PHP 更新 MySQL 表中的数据 在 PH…

    2025年11月9日 后端开发
    000
  • ThinkPHP开发经验分享:解决常见的数据库操作问题

    作为一名开发者,我们经常会遇到数据库操作问题,这些问题可能会耗费我们很多时间和精力来解决。在这篇文章中,我将分享一些我在使用ThinkPHP进行开发时遇到的一些常见的数据库问题以及解决方法。 数据库连接问题 首先,让我们从最基本的问题开始:数据库连接问题。如果您的网站或应用程序无法连接到数据库,那么…

    2025年11月7日
    000
  • 怎样在VSCode里进行数据库操作?

    安装SQLTools及对应数据库驱动后,通过命令面板创建连接并填写主机、端口、用户名等信息,保存后可在VSCode中新建.sql文件执行查询,支持多数据库管理、表结构查看、结果导出等功能。 vscode 本身不是数据库管理工具,但通过安装扩展可以方便地连接和操作数据库。最常用的方式是使用 sqlto…

    开发工具 2025年11月7日
    000
  • 六条比较有用的MySQL数据库操作的SQL语句小结

    本文我们主要介绍了MySQL数据库中的六条比较有用的SQL语句,对于初学者来说,可以直接套用下面的格式即可完成相应的功能,希望本次的介绍能够对您有所帮助。 在MySQL数据库操作中,我们常常编写一些SQL语句来实现自己想要的功能。但是对于初学MySQL数据库的人来说这似乎又有一定的难度。本文我们总结…

    数据库 2025年11月7日
    000
  • PHP开发之程序员必掌握的 SQL 指南

    介绍 SQL 已经应用到了我们周围的各个角落,不管你信不信。操纵任何种类数据的每个应用程序都需要将数据存放在某处。无论它是大数据,还是只有简单数行的数据包;无论是政府、还是创业公司;无论是横跨多台服务器的大型数据库、还是运行着自己小型数据库的手机,SQL 无处不在。 但是,SQL 是什么呢?SQL …

    2025年11月7日 数据库
    000
  • MySQL中如何使用FULL OUTER JOIN函数获取两个表的并集

    mysql中如何使用full outer join函数获取两个表的并集 在MySQL中,FULL OUTER JOIN函数是一种融合内连接和外连接的功能强大的连接操作。它可以用于获取两个表的并集,即将两个表中的所有数据合并为一个结果集。本文将介绍FULL OUTER JOIN函数的用法,并提供一些示…

    2025年11月5日
    000
  • ThinkPHP6中如何进行批量操作?

    随着web应用程序的不断发展,批量操作已成为web应用程序中必不可少的功能之一。而在使用thinkphp6进行开发时,处理批量操作也变得易于实现。 在ThinkPHP6中,控制器通常用于处理请求和响应请求。如果要实现批量操作,我们需要使用控制器处理传入的请求,然后将请求分发到相应的操作方法中进行处理…

    2025年11月5日
    000
  • 在ThinkPHP6中如何使用ORM进行数据库操作?

    随着php的发展,越来越多的web应用程序需要访问和操作数据库。orm(object-relational mapping)是一种流行的数据库操作方式,它以面向对象的方式管理数据库,并提供了可维护、可扩展和可移植的解决方案。thinkphp6是一个流行的php框架之一,它提供了很多orm的使用方式,…

    2025年11月5日
    000

发表回复

登录后才能评论
关注微信