快捷查询

快捷查询

1、功能:简化多字段查询条件相同的操作

当表中有多个字段用相同查询条件进行查询时;

  1. 在多个字段之间用 | 分割表示OR查询 如: name|addr
  2. 用 & 分割表示AND查询 如 : name & addr

2、常用语法:

  • OR :
Db::table('表名') ->where('字段1 | 字段2','表达式','条件') -> select();
  • AND :
Db::table('表名') ->where('字段1 & 字段2','表达式','条件') -> select();

3、实例演示:

任务1:查询tp5_staff表中,年龄或工资大于50的员工信息

其实这样的查询毫无意义,仅为演示该方法的使用

  • Index.php 控制器代码:
 field('id,name,hiredate') //设置字段 -> where('age|salary','>',50) //设置查询条件 ->select(); //获取查询结果集 //输出结果集 dump($result); } }
  • 结果说明:不会有工资不到50元的员工,所以输出全部员工记录,此处略去。

  • 生成的SQL语句:

SELECT `id`,`name`,`hiredate` FROM `tp5_staff` WHERE ( `age` > 50 OR `salary` > 50 )

任务2:查询tp5_staff表中,年龄和工资都必须大于50的员工信息

工资不会在小于50元,该查询与查询员工年龄大于50的结果相同

  • Index.php 控制器代码:
 field('id,name,hiredate') //设置字段 -> where('age&salary','>',50) //设置查询条件 ->select(); //获取查询结果集 //输出结果集 dump($result); } }
  • 结果说明:有6条满足条件的记录
array(6) { [0] => array(3) { ["id"] => int(1004) ["name"] => string(9) "小龙女" ["hiredate"] => string(10) "2010-01-20" } [1] => array(3) { ["id"] => int(1006) ["name"] => string(9) "西门庆" ["hiredate"] => string(10) "2016-11-14" } [2] => array(3) { ["id"] => int(1008) ["name"] => string(6) "宋江" ["hiredate"] => string(10) "2016-11-20" } [3] => array(3) { ["id"] => int(1023) ["name"] => string(9) "段王爷" ["hiredate"] => string(10) "2015-12-31" } [4] => array(3) { ["id"] => int(1024) ["name"] => string(9) "鲁大师" ["hiredate"] => string(10) "2012-09-09" } [5] => array(3) { ["id"] => int(1028) ["name"] => string(6) "方方" ["hiredate"] => string(10) "2015-12-31" } }
  • 生成的SQL语句:
SELECT `id`,`name`,`hiredate` FROM `tp5_staff` WHERE ( `age` > 50 AND `salary` > 50 )
  • SQLPRO for MySQL 运行截图:

4、注意:

位于二个查询字段之间的操作符“|”和"&",与字段名之间不能有空格,切记
[ 正确 ] : age|salary ; age&salary ;
[ 错误 ] : age空格 | 空格 salary; age 空格 & 空格 salary ;