Laravel 4使用2个数据库列填充下拉列表?

时间:2014-02-16 20:51:43

标签: php laravel laravel-4

echo Form::select(
    'campaign_user_id',
    User::find(1)->profile->lists('first_name', 'id'),
    Input::get('campaign_user_id', $campaign->user_id),
    array(
      "placeholder" => "US",
      'class' => 'form-control',
      'disabled' => 'disabled'
    )
)

上面的代码用于构建下拉列表选择列表。它从数据库中获取用户列表。在第3行,您可以看到User::find(1)->profile->lists('first_name', 'id')

它正在获取first_name列,我需要以某种方式获取名字和姓氏列,并将它们组合在此列表中。因此列表值仍然是用户ID,并显示全名。

知道如何使用2个数据库列first_namelast_name来完成此工作吗?或者达到我最终目标的另一种方法?

1 个答案:

答案 0 :(得分:6)

//在你的模特中

class User extends Eloquent
{
    public function getFullNameAttribute()
    {
        return $this->attributes['first_name'] . ' ' . $this->attributes['last_name'];
    }
}

然后像这样抓住:

User::find(1)->profile->lists('full_name', 'id');

OR

User::find(1)->profile->select(DB::raw('concat (first_name," ",last_name) as full_name,id'))->lists('full_name', 'id');

我更喜欢第一个:)