
用过5.0的开发者都比较依靠5.0的数组查询体式格局,然则很无法5.1的数组查询体式格局和5.0的区分很大,因而常常听到开发者埋怨5.1的数组查询不好用。
起首,出于平安和易用性的缘由,官方是不引荐运用数组查询前提的,其次,你或许不知道5.1版本实在供应了一个新的数组对象查询的体式格局用以替换之前的数组前提。
假如你的版本是V5.1.21+的话,那末能够尝试下面提到的数组对象查询体式格局,肯定会有不测的欣喜^_^
关于习气或许重度依靠数组查询前提的用户来讲,能够挑选数组对象查询,该对象完成了平常数组体式格局查询和体系的查询表达式之间的桥接,但相较于体系引荐的查询表达式体式格局而言,须要注重变量的平安性,防止发生SQL注入的状况。
要运用数组对象查询,你起首须要引入think\db\Where类。
use think\db\Where;
Where对象的用法平常有两种,第一种最简朴,你依旧和5.0一样运用数组前提举行定义查询前提,比方:
$map = [ 'name' => ['like', 'thinkphp%'], 'title' => ['like', '%think%'], 'id' => ['>', 10], 'status' => 1, ];
然后,在实际运用where要领的时刻改成
Db::name('user') ->where(new Where($map)) ->select();
生成的SQL是:
SELECT * FROM `think_user` WHERE `name` LIKE 'thinkphp%' AND `title` LIKE '%think%' AND `id` > 10 AND `status` =1
这类体式格局最轻易革新,相当于一键切换到5.0的数组查询体式格局。固然,除了Db查询以外,模子查询也一样能够支撑。
第二种体式格局是,直接实例化一个Where对象,然后在where要领查询的时刻直接传入该Where对象实例。
$where = new Where; $where['id'] = ['in', [1, 2, 3]]; $where['title'] = ['like', '%php%']; Db::name('user') ->where($where) ->select();
Where对象完成了ArrayAccess接口,因而能够直接当做数组来赋值。
生成的SQL是:
SELECT * FROM `think_user` WHERE `id` IN (1,2,3) AND `title` LIKE '%php%'
运用Where对象查询能够和别的的查询体式格局夹杂运用。假如你在夹杂运用数组查询对象的时刻,愿望某个数组查询对象的查询前提加上括号,能够运用
$where = new Where; $where['id'] = ['in', [1, 2, 3]]; $where['title'] = ['like', '%php%']; Db::name('user') ->where($where->enclose()) ->where('status', 1) ->select();
生成的SQL是:
SELECT * FROM `think_user` WHERE ( `id` IN (1,2,3) AND `title` LIKE '%php%' ) AND `status` =1
enclose要领示意该查询前提双方会加上括号包起来。
运用数组对象查询的状况请肯定要注重做好数据类型搜检,只管防止让用户决议你的数据,从而致使SQL注入的大概。
ki4网,有大批免费的ThinkPHP入门教程,迎接人人进修!
本文转自:https://blog.thinkki4.cn/778497
以上就是ThinkPHP5.1:数组对象查询的运用的细致内容,更多请关注ki4网别的相干文章!