mysql查询最小的thinkphp_表达式查询(重点)

这篇博客详细介绍了如何使用ThinkPHP进行MySQL查询,包括相等、不等、大于、小于等比较操作,模糊查询,区间查询,集合查询以及判断字段是否为空的操作方法,并给出了相应的SQL语句示例。
摘要由CSDN通过智能技术生成

表达式查询where('字段名','表达式','查询条件');

whereOr('字段名','表达式','查询条件');

后面全部以 where方法来举例因表达式条件各不相同,有的结果是一个集合,我们只给出生成的SQL语句,不再给出运行结果,请上机测试!相信大家对运行结果都有预测能力

1、相等 (' eq ' 或 ' = ')实例:查询think_user表中,id等于3的记录,由于id为主键,所以只有一条返回记录//1、字符串:eq

$result = Db::table('tp5_staff') -> where('id','eq',1010) -> select();

//2、操作符号:=

$result = Db::table('tp5_staff') -> where('id','=',1010) -> select();

//3、默认为相等,所以中间操作符可省略

$result = Db::table('tp5_staff') -> where('id',1010) -> select();

//输出查询结果

dump($result);以上三种方式,查询结果完全相同

对应SQL语句:SELECT * FROM  tp5_staff WHERE id = 1010 ;

2、不相等 ('neq' 或 ' <> ')实例:查询tp5_staff表中,id 不等 1020 的所有记录(除id=1020之外)//1、字符串:neq

$result = Db::table('tp5_staff') -> where('id','neq',1020) -> select();

//2、操作符号:<>

$result = Db::table('tp5_staff') -> where('id','<>',1020) -> select();

//输出查询结果

dump($result);对应SQL语句:SELECT * FROM `tp5_staff` WHERE `id` <> 1020 ;

3、大于 (' gt ', ' > ')实例:查询tp5_staff表中,id 大于1020的记录,返回一个数组//1、字符串:gt

$result = Db::table('tp5_staff') -> where('id','gt',1020) -> select();

//2、操作符号:>

$result = Db::table('tp5_staff') -> where('id','>',1020) -> select();

//输出查询结果

dump($result);生成的SQL语句:SELECT * FROM `tp5_staff` WHERE `id` > 1020 ;

4、大于等于 (' egt ',' >= ')//1、字符串:egt

$result = Db::table('tp5_staff') -> where('id','egt',1020) -> select();

//2、操作符号:>=

$result = Db::table('tp5_staff') -> where('id','>=',1020) -> select();

//输出查询结果

dump($result);生成的SQL语句:SELECT * FROM `tp5_staff` WHERE `id` >= 1020 ;

5、小于 (' lt ',' < ')实例:查询tp5_staff表中,id 小于1020的记录,返回一个数组//1、字符串:lt

$result = Db::table('tp5_staff') -> where('id','lt',1020) -> select();

//2、操作符号:<

$result = Db::table('tp5_staff') -> where('id',' select();

//输出查询结果

dump($result);生成的SQL语句:SELECT * FROM `tp5_staff` WHERE `id` 

6、小于等于 (' elt ',' <= ')//1、字符串:elt

$result = Db::table('tp5_staff') -> where('id','elt',1020) -> select();

//2、操作符号:<=

$result = Db::table('tp5_staff') -> where('id','<=',1020) -> select();

//输出查询结果

dump($result);生成的SQL语句:SELECT * FROM `tp5_staff` WHERE `id` <= 1020 ;

7、模糊查询 (' like ')实例:查询name字段包括”张”字符的记录//模糊查询:like

$result = Db::table('tp5_staff') -> where('name','like','%张%') -> select();

//输出查询结果

dump($result);生成的SQL语句:SELECT * FROM `tp5_staff` WHERE `name` LIKE '%合肥%' ;

8、区间查询 (between)语法:where(字段,’between’,’区间’); 区间字符串,第一个是最小值,第二个是最大值

例如:where(‘id’,’betweet’,’5,20’);表示id取值范围从5到20,很直观。

注:区间字符串,也可以用数组替代,推荐用数组,显示更专业,规范。where(‘id’,’between’,[5,20]);实例:查询id在1010到1020之间的记录信息//区间用字符串表示

$result = Db::table('tp5_staff') -> where('id','between','1010,1020') -> select();

//区间用数组表示

$result = Db::table('tp5_staff') -> where('id','between',[1010,1020]) -> select();

//输出查询结果

dump($result);生成的SQL语句:SELECT * FROM `tp5_staff` WHERE `id` BETWEEN 1010 AND 1020 ;

9、集合查询 (' in ' , ' not in ')说明:查询字段的值,必须在或者不在某一个集合内,集合是一个个离散的枚举字面量

例如:where(‘id’,’in’,’9,11,21’); 或者 where(‘id’,’not in’,’9,10,20’);同上,第三个字符串可用数组代替

实例:查询id 等于 1003,1005,1020 的数据,返回一个数组//集合用字符串表示

$result = Db::table('tp5_staff') -> where('id','in','1003,1005,1020') -> select();

// 取反,即不在某个集合内  not in

$result = Db::table('tp5_staff') -> where('id','not in','1003,1005,1020') -> select();

//集合用数组表示

$result = Db::table('tp5_staff') -> where('id','in',[1003,1005,1020]) -> select();

// 取反,即不在某个集合内  not in

$result = Db::table('tp5_staff') -> where('id','not in',[1003,1005,1020]) -> select();返回是三个元素的数组,即id=1003、id=1005和id = 1020的三条记录

生成SQL语句:SELECT  *  FROM `tp5_staff` WHERE `id` IN (1003,1005,1020) ;

10、是否为空 (null, not null)如果判断某字段是否存在值,只需要二个参数,要注意//判断sex字段是否存在值 null

$result = Db::table('tp5_staff') -> where('sex','null')-> select();

//条件取反:不为空 not null

$result = Db::table('tp5_staff') -> where('sex','not null')-> select();

//如果要判断一个字段值是否为空,要三个参数,中间为'='

$result = Db::table('tp5_staff') -> where('sex','=','null')-> select();

//条件取反:不为空 not null

$result = Db::table('tp5_staff') -> where('sex','=','not null')-> select();生成的SQL语句(仅以字段是否不为空举例)SELECT  *  FROM `tp5_staff` WHERE `sex` IS NOT NULL

总结:本节课以理论为主,具体实例也很简单,请同学们亲自上机做一下,举一反三

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值