首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >当值为false时,laravel orWhere会产生意外结果

当值为false时,laravel orWhere会产生意外结果
EN

Stack Overflow用户
提问于 2019-04-04 19:54:55
回答 2查看 44关注 0票数 0

我写了一个查询

代码语言:javascript
复制
Order::where(function ($query) use ($request) {
      $query->where('email', $request->email_or_mobile)
            ->orWhere('mobile_no', $request->email_or_mobile);
    })
    ->where('transaction_no', $request->reference_no)
    ->count();

$request->email_or_mobile不是false时,这个查询是可以的。但是当false它跳过的时候

代码语言:javascript
复制
where(function ($query) use ($request) {
      $query->where('email', $request->email_or_mobile)
            ->orWhere('mobile_no', $request->email_or_mobile);
    })

并给出了->where('transaction_no', $request->reference_no)条件的结果。为什么我会有这种连线行为?

EN

回答 2

Stack Overflow用户

发布于 2019-04-04 20:15:05

当您的$request->email_or_mobile为false时,您的sql中将有一个条件false == false,结果为true,因此您的sql将是这样的SELECT * FROM order WHERE (false = false) and transaction_no=?,这意味着订单将只按transaction_no进行过滤。

票数 0
EN

Stack Overflow用户

发布于 2019-04-04 20:05:25

代码语言:javascript
复制
Order::where('email', $request->email_or_mobile)
    ->orWhere(function($query) use ($request) {
            ->Where('mobile_no', $request->email_or_mobile);
    })
    ->where('transaction_no', $request->reference_no)
    ->count();

尝尝这个。

票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/55515405

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档