php5.5++查询数据库,快捷查询 - ThinkPHP5数据库实例详解 - php中文网手册

快捷查询

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

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

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

用 & 分割表示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 控制器代码:

namespace app\index\controller;

//导入数据库类

use think\Db;

class Index {

public function index(){

$result = Db::table('tp5_staff') // 选择数据表

-> 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 控制器代码:

namespace app\index\controller;

//导入数据库类

use think\Db;

class Index {

public function index(){

$result = Db::table('tp5_staff') // 选择数据表

-> 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 运行截图:

cb9c1a5a89385f068975407c4547bb10.png

4、注意:

位于二个查询字段之间的操作符“|”和"&",与字段名之间不能有空格,切记

[ 正确 ] : age|salary ; age&salary ;

[ 错误 ] : age空格 | 空格 salary; age 空格 & 空格 salary ;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值