繁体   English   中英

在Laravel查询中的where条件中使用数字

[英]Use number in where condition in Laravel Query

下面的查询在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();

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

查询构建器的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();

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM