Thinkphp5使用model模型操作数据库(2)

//方法二:

$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 = u s e r − > a l l o w F i e l d ( [ ′ n a m e ′ , ′ a g e ′ ] ) − > s a v e ( user->allowField(['name', 'age'])->save( user>allowField([name,age])>save(data);

5、模型使用allowField()过滤非数据表字段的数据

//定义模型对象,并传入post数据

u s e r = n e w U s e r ( user = new User( user=newUser(_POST);

//过滤post数组中的非数据表字段数据

$user->allowField(true)->save();

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

$user = new User;

// post数组中只有name和email字段会写入

u s e r − > a l l o w F i e l d ( [ ′ n a m e ′ , ′ e m a i l ′ ] ) − > s a v e ( user->allowField(['name','email'])->save( user>allowField([name,email])>save(_POST, [‘id’ => 1]);

7、批量添加使用saveAll()

user = new User;

$list = [

[‘name’=>‘安阳’,‘email’=>‘thinkphp@qq.com’],

[‘name’=>‘小柒’,‘email’=>‘12345678@qq.com’]

];

u s e r − > s a v e A l l ( user->saveAll( 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 = u s e r − > a l l o w F i e l d ( [ ′ n a m e ′ , ′ a g e ′ ] ) − > s a v e A l l ( user->allowField(['name', 'age'])->saveAll( 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 app\index\model; use think\Model; 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 app\index\model; use think\Model; 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 app\index\model; use think\Model; class User extends Model { //添加和修改时,都会自动完成的字段 protected $auto = ['addtime']; public function setAddtimeAttr(){ return time(); } } 2、添加数据时,自动完成  <?php namespace app\index\model; use think\Model; class User extends Model { // 新增 自动完成 protected $insert = ['addtime']; **自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。** **深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!** **因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。** ![img](https://img-blog.csdnimg.cn/img_convert/fb06cfb8110daf34d067f1ce554df8ba.png) ![img](https://img-blog.csdnimg.cn/img_convert/c5a342a75ae28f978fb43bcc5582585b.png) ![img](https://img-blog.csdnimg.cn/img_convert/53490d1bcf9e26e48e35bf00bf7dd67b.png) ![img](https://img-blog.csdnimg.cn/img_convert/faeeda3143cabe9e5dbbb6d803b7237a.png) ![](https://img-blog.csdnimg.cn/img_convert/19290f64987d5ff93558b64f3c86b8e8.png) **既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!** **由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!** **如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)** # 最后 我一直以来都有整理练习大厂面试题的习惯,有随时跳出舒服圈的准备,也许求职者已经很满意现在的工作,薪酬,觉得习惯而且安逸。 不过如果公司突然倒闭,或者部门被裁减,还能找到这样或者更好的工作吗? 我建议各位,多刷刷面试题,知道最新的技术,每三个月可以去面试一两家公司,因为你已经有不错的工作了,所以可以带着轻松的心态去面试,同时也可以增加面试的经验。 我可以将最近整理的一线互联网公司面试真题+解析分享给大家,大概花了三个月的时间整理2246页,帮助大家学习进步。 > **由于篇幅限制,文档的详解资料太全面,细节内容太多,所以只把部分知识点截图出来粗略的介绍,每个小节点里面都有更细化的内容!以下是部分内容截图:** ![](https://img-blog.csdnimg.cn/img_convert/a64ab0e362d51f842d02a23af79e15e0.webp?x-oss-process=image/format,png) ![部分目录截图](https://img-blog.csdnimg.cn/img_convert/8cbfaa1b0b5fb02e3943387371ce7dfb.webp?x-oss-process=image/format,png) **《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》[点击传送门即可获取!](https://bbs.csdn.net/forums/f76c2498e3b04ae99081eaf6e6cf692c)** 779)] [外链图片转存中...(img-tw2pgqaq-1713412026781)] [外链图片转存中...(img-wJo3Lmaw-1713412026782)] [外链图片转存中...(img-b2taMm3C-1713412026783)] [外链图片转存中...(img-vcCInDX3-1713412026784)] **既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!** **由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!** **如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)** # 最后 我一直以来都有整理练习大厂面试题的习惯,有随时跳出舒服圈的准备,也许求职者已经很满意现在的工作,薪酬,觉得习惯而且安逸。 不过如果公司突然倒闭,或者部门被裁减,还能找到这样或者更好的工作吗? 我建议各位,多刷刷面试题,知道最新的技术,每三个月可以去面试一两家公司,因为你已经有不错的工作了,所以可以带着轻松的心态去面试,同时也可以增加面试的经验。 我可以将最近整理的一线互联网公司面试真题+解析分享给大家,大概花了三个月的时间整理2246页,帮助大家学习进步。 > **由于篇幅限制,文档的详解资料太全面,细节内容太多,所以只把部分知识点截图出来粗略的介绍,每个小节点里面都有更细化的内容!以下是部分内容截图:** [外链图片转存中...(img-EfXDMzDN-1713412026785)] [外链图片转存中...(img-bgE5wMPI-1713412026786)] **《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》[点击传送门即可获取!](https://bbs.csdn.net/forums/f76c2498e3b04ae99081eaf6e6cf692c)**
  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值