繁体   English   中英

Laravel 5.4子查询在哪里条件?

[英]Laravel 5.4 subquery in where condition?

我想在条件和子查询条件的内部写子查询,用父查询字段检查。

如下,

$query = DB::table('users');
$query->whereNotIn('users.id', function($query) use ($request) {
            $query->select('award_user.user_id')
                    ->from('award_user')
                    ->where('award_user.user_id', 'users.id')
                    ->where('award_user.award_id', $request->award_id);
        });

查询工作正常,但是

 ->where('award_user.user_id', 'users.id')

这行,users.id不是从父查询中获取的。 如果我手动输入数字,那么它正常工作。

我的查询有什么问题..你可以建议吗?

使用whereRaw而不是where

$query = DB::table('users');
$query->whereNotIn('users.id', function($query) use ($request) {
            $query->select('award_user.user_id')
                    ->from('award_user')
                    ->whereRaw('award_user.user_id', 'users.id')
                    ->whereRaw('award_user.award_id = '.$request->award_id);
        });

暂无
暂无

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

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