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模型的获取器
<?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 { **自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。** **深知大多数Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!** **因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。** ![img](https://img-blog.csdnimg.cn/img_convert/b6f9b8086c45b7f026b179dfb80b9266.png) ![img](https://img-blog.csdnimg.cn/img_convert/ac59b55711cac87c6df1b248dca50ce5.png) ![img](https://img-blog.csdnimg.cn/img_convert/b965f184e7af3d04300f19fba2c2d46b.png) ![img](https://img-blog.csdnimg.cn/img_convert/95337d89b7c669e3c70aff55d3d5e911.png) ![img](https://img-blog.csdnimg.cn/img_convert/b1d444f9653221104a7256d5dfc00bee.png) ![img](https://img-blog.csdnimg.cn/img_convert/0f1c4c26bffeb1bbb83c8a7e61fc98a0.png) ![img](https://img-blog.csdnimg.cn/13f2cb2e05a14868a3f0fd6ac81d625c.png) **既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!** **由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新** **如果你觉得这些内容对你有帮助,可以添加V获取:vip204888 (备注Android)** ![img](https://img-blog.csdnimg.cn/img_convert/dd2a4734a519fb89e67532f6b5b17701.png) ### 尾声 对于很多初中级Android工程师而言,想要提升技能,往往是自己摸索成长,不成体系的学习效果低效漫长且无助。 整理的这些架构技术希望对Android开发的朋友们有所参考以及少走弯路,本文的重点是你有没有收获与成长,其余的都不重要,希望读者们能谨记这一点。 最后想要拿高薪实现技术提升薪水得到质的飞跃。最快捷的方式,就是有人可以带着你一起分析,这样学习起来最为高效,所以为了大家能够顺利进阶中高级、架构师,我特地为大家准备了一套高手学习的源码和框架视频等精品Android架构师教程,保证你学了以后保证薪资上升一个台阶。 * **思维脑图** ![](https://img-blog.csdnimg.cn/img_convert/9ec0f16bd74116572975d47b5931a82f.webp?x-oss-process=image/format,png) * **性能优化学习笔记** ![](https://img-blog.csdnimg.cn/img_convert/96d88f2c810216a41779b95467c471ed.webp?x-oss-process=image/format,png) ![](https://img-blog.csdnimg.cn/img_convert/cb776c88fa874deea0fab3933507de34.webp?x-oss-process=image/format,png) ![](https://img-blog.csdnimg.cn/img_convert/b2981e78ea1d389faa0ee3f1a9c2494a.webp?x-oss-process=image/format,png) ![](https://img-blog.csdnimg.cn/img_convert/bcea6051f19ac234d22702e11b409cb8.webp?x-oss-process=image/format,png) * **性能优化视频** ![](https://img-blog.csdnimg.cn/img_convert/ac097d433a153bdd68a0357df8b278a0.webp?x-oss-process=image/format,png) 当你有了学习线路,学习哪些内容,也知道以后的路怎么走了,理论看多了总要实践的。 会持续更新** **如果你觉得这些内容对你有帮助,可以添加V获取:vip204888 (备注Android)** [外链图片转存中...(img-gL5Ud9nD-1711805325121)] ### 尾声 对于很多初中级Android工程师而言,想要提升技能,往往是自己摸索成长,不成体系的学习效果低效漫长且无助。 整理的这些架构技术希望对Android开发的朋友们有所参考以及少走弯路,本文的重点是你有没有收获与成长,其余的都不重要,希望读者们能谨记这一点。 最后想要拿高薪实现技术提升薪水得到质的飞跃。最快捷的方式,就是有人可以带着你一起分析,这样学习起来最为高效,所以为了大家能够顺利进阶中高级、架构师,我特地为大家准备了一套高手学习的源码和框架视频等精品Android架构师教程,保证你学了以后保证薪资上升一个台阶。 * **思维脑图** [外链图片转存中...(img-ynAiCmYq-1711805325122)] * **性能优化学习笔记** [外链图片转存中...(img-XkrugWQY-1711805325122)] [外链图片转存中...(img-ZEPXIfrF-1711805325122)] [外链图片转存中...(img-JY0rf9SN-1711805325122)] [外链图片转存中...(img-mWj6FWc2-1711805325123)] * **性能优化视频** [外链图片转存中...(img-nCdpcVGX-1711805325123)] 当你有了学习线路,学习哪些内容,也知道以后的路怎么走了,理论看多了总要实践的。 > **本文已被[CODING开源项目:《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》]( )收录**读取器的命名规范是:->get + 属性名的驼峰命名 + Attr