php instr,TP 框架没有考虑完善的功能点:1、表达式查询不支持INSTR形式的查询

如题

TP框架支持表达式查询,LT IN BETWEEN等,还可以使用 EXP 来表征直接使用原生级的表达式,但此方式都是以关联数组,key(column) => value(other condition) 的方式,而且解析时都是以 key other condition 的方式,比如 ["id"] => ["EXP", "IN (1, 2, 3, 4)"] 会被解析为 `id` IN (1, 2, 3, 4),但当你想要使用 INSTR 类型的查询就做不到了:

比如 WHERE INSTR(`id_set`, "1,"),我们想查询在 `id_set` 字段中含有给定的数值数据,这里与 IN 不同在于字段名是被包含在了函数里,而不是 column condition 的这种方式,但 TP 的解析都是按 key 为 column,value 为 condition 另作解析的方式来解析表达式查询的关联数组。

改进很简单,甚至说很鸡肋,不过我觉得平时还是会有人在某些场景下需要这种功能吧

ThinkPHP\Library\Think\Db\Driver.class.php

\Think\Db\Driver::parseWhereItem

在 exp 的判断分支中

if ('exp' == $exp) { // 使用表达式

$whereStr .= $key . ' ' . $val[1];

}

改为(代码里是 elseif 判断 我为了好看所以 if 了 请灵活理解)

if ('exp' == $exp) { // 使用表达式

if ($val[2]) { // ["EXP", "INSTR(`id_set`, $id)", true]

$whereStr .= $val[1];

} else {

$whereStr .= $key . ' ' . $val[1];

}

}

增加第三个元素,true 为隐士表达式查询,默认为 false 显示表达式查询,也就是TP默认的

后期使用只需要

$map = [

"age" => ["LT", $age],

"name" => ["EXP", ["INSTR(`name`, '$name')"], true]

];

即可

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值