在Laravel Eloquent中使用“with()”函数的Concat列

时间:2015-04-08 19:11:24

标签: php sql select laravel eloquent

我正在尝试 concat 将不同表中的两列列合为一列。

$user = User::with(array('Person'=>function($query){
    $query->selectRaw('CONCAT(prefix_person.name, " - ", prefix_user.code) as name, prefix_user.id');
}))->lists('name', 'id');

在我的person class我有这个方法:

public function User()
{
    return $this->hasOne('User');
}

在我user class我有这个:

public function Person()
{
    return $this->belongsTo('Person', 'person_id');
}

我收到以下错误:

SQLSTATE[42S22]: Column not found: 1054 Unknown column 'name' in 'field list' (SQL: select `name`, `id` from `prefix_user`)

当我尝试

$user = User::with(array('Person'=>function($query){
    $query->selectRaw('CONCAT(prefix_person.name, " - ", prefix_user.code) as name, prefix_user.id')->lists('name', 'id');
}));

我收到了这个错误:

error


我曾多次使用过selectRaw,但从未将其用于(加入)。

2 个答案:

答案 0 :(得分:7)

问题在于,Eloquent将首先查询users表,并且只在查询人员表之后,因此一个查询不知道另一个查询,因此连接将不起作用。

您可以使用join使用$user = DB::table('users as u') ->join('persons as p', 'p.id', '=', 'u.person_id') ->selectRaw('CONCAT(p.name, " - ", u.code) as concatname, u.id') ->lists('concatname', 'u.id'); 来执行此操作。它会是这样的:

public function getFullNameAttribute() { 
    return $this->attributes['name'] . ' - ' . $this->attributes['code'];
}

编辑: 并且,正如@ michel-ayres评论所建议的那样,只要您有该领域的后继者:

User::join('person','person.id','=','user.person_id')
    ->select('person.name', 'user.code', 'user.id')
    ->get()
    ->lists('full_name', 'id');

您可以使用自己的模型来执行加入和列表:

{{1}}

答案 1 :(得分:1)

您只需使用简单查询即可解决此问题

User::join('persons as p', 'p.id', '=', 'users.person_id')
       ->get([
            'id',
            DB::raw('CONCAT(p.name,"-",users.code) as name')
        ])
       ->lists('name', 'id');

或者,看另一种方式

User::join('persons as p', 'p.id', '=', 'users.person_id')
      ->select(
          'id',
          DB::raw('CONCAT(p.name,"-",users.code) as name')

        )
       ->lists('name', 'id');