laravel orm调用count方法会不理会其他的一些参数

在一个ORM实体类中, 我使用如下代码:

$this->where('status', 1)
->where('user_id', '<>', NULL)
->distinct('gateway_id')
->select(\DB::raw('distinct(`gateway_id`)'))
->count('gateway_id');

打印出来的sql是:select count(*) as aggregate from `user_gateway_bind` where `status` = ? and `user_id` is not null==>params{[1]}
这里我想想中的sql不一致, 我想象中的SQL是select distinct(gateway_id)这种
下面是正常的ORM调用方式
$this->where('status', 1)
->where('user_id', '<>', NULL)
->distinct('gateway_id')
->count('gateway_id');

使用ORM的时候我经常会忘记count方法是可以进入实参的, distinct方法我在源代码中看到是没有参数中, 这里写了参数也不会报错, 不知道为什么。
最近一段时间都是在写代码,没怎么去看源代码, 感觉需要去看下源代码了。

转载于:https://www.cnblogs.com/zzx11235/articles/5867930.html

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值