微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

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->列表(‘first_name’,’id’)

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

知道如何使用2个DB列first_name和last_name进行此操作吗?或者达到我最终目标的另一种方法

解决方法:

//在你的模特中

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

然后像这样抓住:

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

要么

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

我更喜欢第一个:)

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐