一文详解Thinkphp5中怎么增删改查数据库
发布时间 - 2022-02-10 00:00:00 点击率:次thinkphp5中怎么操作数据库,进行增删改查?下面本篇文章就来带大家详细了解一下thinkphp5中增删改查数据库的方法,希望对大家有所帮助!
thinkphp标准数据表设计:创建时间字段:create_time更新时间字段:update_time删除时间字段:delete_time 类型选int,如下图:
【相关教程推荐:thinkphp框架】
一、创建model的文件夹
在application文件夹下的二级对象目录中新建名为model的文件夹,该文件夹与对应的controller和view目录同级,如下图:
如果有多个模块(比如前台index,后台admin),操作的数据库都差不多,那么可以把model模型放到common公共模块里,如下:
二、创建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', ['2025-3-28', '2025-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视频教程》
# php # thinkphp # select # auto # int # 对象 # database # 数据库 # unix # 安阳 # 自动完成 # 行数 # 支付宝 # 可以使用 # 主键 # 则会 # 多条 # 修改器 # 条数
相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571 】
相关推荐: 如何在万网自助建站中设置域名及备案? 图片制作网站免费软件,有没有免费的网站或软件可以将图片批量转为A4大小的pdf? 如何用PHP工具快速搭建高效网站? ,在苏州找工作,上哪个网站比较好? Python面向对象测试方法_mock解析【教程】 如何在建站宝盒中设置产品搜索功能? JS经典正则表达式笔试题汇总 想要更高端的建设网站,这些原则一定要坚持! Laravel怎么实现软删除SoftDeletes_Laravel模型回收站功能与数据恢复【步骤】 公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站? Laravel Octane如何提升性能_使用Laravel Octane加速你的应用 大连网站制作费用,大连新青年网站,五年四班里的视频怎样下载啊? Internet Explorer官网直接进入 IE浏览器在线体验版网址 Laravel如何处理JSON字段的查询和更新_Laravel JSON列操作与查询技巧 html5如何设置样式_HTML5样式设置方法与CSS应用技巧【教程】 如何快速生成橙子建站落地页链接? 如何用景安虚拟主机手机版绑定域名建站? 网站优化排名时,需要考虑哪些问题呢? 如何用虚拟主机快速搭建网站?详细步骤解析 微信小程序 canvas开发实例及注意事项 php 三元运算符实例详细介绍 Laravel如何使用集合(Collections)进行数据处理_Laravel Collection常用方法与技巧 Laravel如何实现多级无限分类_Laravel递归模型关联与树状数据输出【方法】 今日头条微视频如何找选题 今日头条微视频找选题技巧【指南】 Gemini怎么用新功能实时问答_Gemini实时问答使用【步骤】 如何快速完成中国万网建站详细流程? Python图片处理进阶教程_Pillow滤镜与图像增强 Laravel Seeder怎么填充数据_Laravel数据库填充器的使用方法与技巧 如何在沈阳梯子盘古建站优化SEO排名与功能模块? 如何在 Telegram Web View(iOS)中防止键盘遮挡底部输入框 JS中使用new Date(str)创建时间对象不兼容firefox和ie的解决方法(两种) Angular 表单中正确绑定输入值以确保提交与验证正常工作 企业网站制作这些问题要关注 Laravel如何使用Passport实现OAuth2?(完整配置步骤) 如何制作公司的网站链接,公司想做一个网站,一般需要花多少钱? 利用python获取某年中每个月的第一天和最后一天 Win10如何卸载预装Edge扩展_Win10卸载Edge扩展教程【方法】 高防网站服务器:DDoS防御与BGP线路的AI智能防护方案 如何在新浪SAE免费搭建个人博客? Laravel如何使用Eloquent进行子查询 Laravel怎么实现支付功能_Laravel集成支付宝微信支付 Laravel安装步骤详细教程_Laravel环境搭建指南 Python数据仓库与ETL构建实战_Airflow调度流程详解 Laravel怎么设置路由分组Prefix_Laravel多级路由嵌套与命名空间隔离【步骤】 php结合redis实现高并发下的抢购、秒杀功能的实例 Laravel如何使用Spatie Media Library_Laravel图片上传管理与缩略图生成【步骤】 b2c电商网站制作流程,b2c水平综合的电商平台? Laravel怎么定时执行任务_Laravel任务调度器Schedule配置与Cron设置【教程】 Laravel如何实现用户密码重置功能?(完整流程代码) 成都品牌网站制作公司,成都营业执照年报网上怎么办理?


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