Thinkphp5使用model模型操作数据库,vivoandroid面试

不等于

->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、添加数据,并返回添加的主键

Thinkphp5使用model模型操作数据库,vivoandroid面试_第1张图片

$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’ => ‘[email protected]

];

//只有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’=>‘[email protected]’],

[‘name’=>‘小柒’,‘email’=>‘[email protected]’]

];

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’ => ‘[email protected]

],

[

‘name’ => ‘小柒’,

‘age’ => 25,

‘email’ => ‘[email protected]

]

];

$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

**auto**       新增及更新的时候,自动完成的属性数组 > **insert**     仅新增的时候,自动完成的属性数组 > **update**   仅更新的时候,自动完成的属性数组 1、自动完成  作者2013年从java开发,转做Android开发,在小厂待过,也去过华为,OPPO等大厂待过,18年四月份进了阿里一直到现在。 参与过不少面试,也当面试官 面试过很多人。深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,不成体系的学习效果低效漫长,而且极易碰到天花板技术停滞不前! 我整理了一份阿里P7级别的最系统的Android开发主流技术,特别适合有3-5年以上经验的小伙伴深入学习提升。 主要包括阿里,以及字节跳动,腾讯,华为,小米,等一线互联网公司主流架构技术。**如果你想深入系统学习Android开发,成为一名合格的高级工程师,可以收藏一下这些Android进阶技术选型** > 我搜集整理过这几年阿里,以及腾讯,字节跳动,华为,小米等公司的面试题,把面试的要求和技术点梳理成一份大而全的“ Android架构师”面试 Xmind(实际上比预期多花了不少精力),包含知识脉络 + 分支细节。 > ![](https://img-blog.csdnimg.cn/img_convert/b4633ef683adde475aef22b1e3c2b120.png) **Java语言与原理;** 大厂,小厂。Android面试先看你熟不熟悉Java语言 > ![](https://img-blog.csdnimg.cn/img_convert/46b1fc9c34a6272ac39cf0801882f81f.png) **高级UI与自定义view;** 自定义view,Android开发的基本功。 > ![](https://img-blog.csdnimg.cn/img_convert/0b81cb5653c15cb4b23acc3755da85e1.png) **性能调优;** 数据结构算法,设计模式。都是这里面的关键基础和重点需要熟练的。 > ![](https://img-blog.csdnimg.cn/img_convert/4c48f7d4bb2dbe9293a4e331ad4715d5.png) **NDK开发;** 未来的方向,高薪必会。 > ![](https://img-blog.csdnimg.cn/img_convert/e21f8db203a8ecab4f60b3f594a197e8.png) **前沿技术;** 组件化,热升级,热修复,框架设计 > ![](https://img-blog.csdnimg.cn/img_convert/8b7bd978fc142f9b71e0a8e8ca51e740.png) > 网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。 我在搭建这些技术框架的时候,还整理了系统的高级进阶教程,会比自己碎片化学习效果强太多,CodeChina上可见; 当然,想要深入学习并掌握这些能力,并不简单。关于如何学习,做程序员这一行什么工作强度大家都懂,但是不管工作多忙,每周也要雷打不动的抽出 2 小时用来学习。 **不出半年,你就能看出变化!** d开发,成为一名合格的高级工程师,可以收藏一下这些Android进阶技术选型** > 我搜集整理过这几年阿里,以及腾讯,字节跳动,华为,小米等公司的面试题,把面试的要求和技术点梳理成一份大而全的“ Android架构师”面试 Xmind(实际上比预期多花了不少精力),包含知识脉络 + 分支细节。 > [外链图片转存中...(img-yPg7Bolq-1647533340891)] **Java语言与原理;** 大厂,小厂。Android面试先看你熟不熟悉Java语言 > [外链图片转存中...(img-qSOamcsO-1647533340892)] **高级UI与自定义view;** 自定义view,Android开发的基本功。 > [外链图片转存中...(img-lGDq2UKS-1647533340892)] **性能调优;** 数据结构算法,设计模式。都是这里面的关键基础和重点需要熟练的。 > [外链图片转存中...(img-gnBPhXVr-1647533340893)] **NDK开发;** 未来的方向,高薪必会。 > [外链图片转存中...(img-QKCWvv7z-1647533340893)] **前沿技术;** 组件化,热升级,热修复,框架设计 > [外链图片转存中...(img-gpEIdwgP-1647533340894)] > 网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。 我在搭建这些技术框架的时候,还整理了系统的高级进阶教程,会比自己碎片化学习效果强太多,CodeChina上可见; 当然,想要深入学习并掌握这些能力,并不简单。关于如何学习,做程序员这一行什么工作强度大家都懂,但是不管工作多忙,每周也要雷打不动的抽出 2 小时用来学习。 **不出半年,你就能看出变化!**

你可能感兴趣的:(程序员,数据库,面试,database)