where(id,'in',[1,2])这种写法能否执行

已解决: 5.1的JoinClause.php中有自己的where方法,支持这样写;5.5后将JoinClause.php中的where方法删了,改继承了.这事省的..
where(id,'in',[1,2])这种写法能否执行


问题描述: where应该不支持in的写法,但是我这样写之后在服务器上竟然可以执行.服务器环境php7.1 , laravel5.1;
本地环境 php7.1.6 , laravel5.5 就不能执行.

代码位置
where(id,'in',[1,2])这种写法能否执行

封装的innerJoinOnSomeAnd方法:

where(id,'in',[1,2])这种写法能否执行
服务器上记录的sql日志:

where(id,'in',[1,2])这种写法能否执行

《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
最佳答案

用的func_num_args判断参数是几个,然后再判断第一个是不是闭包,第二个是不是非法操作符,都不是的话就加到builderwheres数组里,最后调用 find,first,get的时候再拼装 sql,可以看下源码Illuminate\Database\Query\Builderwhere方法实现

3年前 评论
讨论数量: 3

1楼教你怎么用了 2楼大佬把源码分析了 3楼帮你总结了 :smirk:

3年前 评论

用的func_num_args判断参数是几个,然后再判断第一个是不是闭包,第二个是不是非法操作符,都不是的话就加到builderwheres数组里,最后调用 find,first,get的时候再拼装 sql,可以看下源码Illuminate\Database\Query\Builderwhere方法实现

3年前 评论

whereIn('id',$homework_ids)

3年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!