作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有两个表Users 和Groups,我想将用户添加到具有 Eloquent 关系 的组中。mysql 表:
组表:
id
name
user_id
用户表:
id
name
email
password
Group.php 模型有:
public function user()
{
return $this->hasMany('App\User');
}
User.php 模型有:
public function group()
{
return $this->belongsTo('App\Group');
}
GroupController.php
public function store(Request $request)
{
$request->validate([
'name'=>'required|string',
'user_id' => 'required',
]);
$group = new Group([
'name' => $request->get('name'),
'user_id'=> $request->get('user_id')
]);
$group->save();
return redirect('/groups')->with('success', 'Group has been added');
}
create.blade.php View
<div class="form-group">
<select name="user_id[]" class="form-control" multiple>
@foreach ($users as $user)
<option value="{{$user->id}}">{{$user->name}}</option>
@endforeach
</select>
</div>
错误是“数组到字符串的转换”如果我在 TeamController 的 save() 之前添加一个“dd($group)”,我会得到 user_ids dd results但是当它尝试 $group->save();我收到错误,有什么帮助吗?谢谢
最佳答案
根据您的表结构,您尝试执行的操作是不可能的。你需要改变你的表结构,
一个组 - 许多用户,
所以,你的表结构应该是,
群组
id
name
用户
id
name
email
password
group_id
你的关系定义应该是,
组模型
public function users()
{
return $this->hasMany('App\User', 'group_id');
}
用户模型
public function group()
{
return $this->belongsTo('App\Group', 'group_id');
}
最后,
public function store(Request $request)
{
$request->validate([
'name'=>'required|string',
'user_id' => 'required|array',
]);
$group = new Group([
'name' => $request->get('name'),
]);
$group->save();
foreach($request->get('user_id') as $id)
{
$user = App\User::findOrFail($id);
$user->group_id = $group->id
$user->save();
}
return redirect('/groups')->with('success', 'Group has been added');
}
关于php - 我想用 Eloquent laravel 5 将人们添加到组中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54551938/
使用登录后,我想吐出用户名。 但是,当我尝试单击登录按钮时, 它给了我力量。 我看着logcat,但是什么也没显示。 这种编码是在说。 它将根据我在登录屏幕中输入的名称来烘烤用户名。 不会有任何密码。
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎是题外话,因为它缺乏足够的信息来诊断问题。 更详细地描述您的问题或include a min
我是一名优秀的程序员,十分优秀!