在Laravel Query中的where where条件中使用数字

时间:2017-03-25 18:33:49

标签: php laravel

以下查询在mysql中运行良好,但如何使用Laravel表示相同的内容。

select * from user_subscription where vendor_id = 'user_100' 
and 0 = (select count(*) from user_restricted_dates where vendor_id = 'user_100')

我尝试使用代码,但在where子句中未知列'0'时出现错误

$list = UserSubscription::where('vendor_id', '=', $vendor_obj->vendor_id)
    ->where(0, '=', "(select count(*) from user_restricted_dates where vendor_id = 'user_100'")
    ->get();

错误表明它是什么,但如何表示

1 个答案:

答案 0 :(得分:2)

查询生成器的where方法将您传递的第一个值映射到模型中的字段。您必须使用whereRaw方法。

$list = UserSubscription::where('vendor_id', '=', $vendor_obj->vendor_id)
    ->whereRaw("0 = (select count(*) from user_restricted_dates where vendor_id = 'user_100')")
    ->get();