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_name
和last_name
来完成此工作吗?或者达到我最终目标的另一种方法?
答案 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');
我更喜欢第一个:)