以下查询在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();
错误表明它是什么,但如何表示
答案 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();