当前位置:Gxlcms > PHP教程 > laravel这个同样两张表取别名查询出错,怎么改呢?

laravel这个同样两张表取别名查询出错,怎么改呢?

时间:2021-07-01 10:21:17 帮助过:2人阅读

$res = DB::table('topics')->select('topics.*', 'b.username',
            'b.avatar', 'c.username as rname', 'd.cname')
            ->where('topics.is_hidden', 0)
            ->leftJoin('users b', 'b.uid', '=', 'topics.uid')
            ->leftJoin('users c', 'c.uid', '=', 'topics.ruid')
            ->leftJoin('nodes d', 'd.node_id', '=', 'topics.node_id')
            ->orderBy('ord', 'desc')
            ->take($limit)->get();

这里错误很多:
Table 'startbbs.stb_users b' doesn't exist
stb_users 我要用到两次,肯定得取别名,怎么办呢

回复内容:

$res = DB::table('topics')->select('topics.*', 'b.username',
            'b.avatar', 'c.username as rname', 'd.cname')
            ->where('topics.is_hidden', 0)
            ->leftJoin('users b', 'b.uid', '=', 'topics.uid')
            ->leftJoin('users c', 'c.uid', '=', 'topics.ruid')
            ->leftJoin('nodes d', 'd.node_id', '=', 'topics.node_id')
            ->orderBy('ord', 'desc')
            ->take($limit)->get();

这里错误很多:
Table 'startbbs.stb_users b' doesn't exist
stb_users 我要用到两次,肯定得取别名,怎么办呢

$res = DB::table('topics')->select('topics.*', 'b.username',
            'b.avatar', 'c.username as rname', 'd.cname')
            ->where('topics.is_hidden', 0)
            ->leftJoin('users AS b', 'b.uid', '=', 'topics.uid')
            ->leftJoin('users AS c', 'c.uid', '=', 'topics.ruid')
            ->leftJoin('nodes AS d', 'd.node_id', '=', 'topics.node_id')
            ->orderBy('ord', 'desc')
            ->take($limit)->get();

人气教程排行