我在Laravel 5.3中遇到了一个问题,我查看了文档并搜索了网页,但没有找到任何内容.
我正在使用Laravel Relationships加入两个表.现在我希望在用户提交表单后同时在两个表上插入数据.这是第一个表是第一个表是主要的说"用户"和第二个"xyz"属于第一个表.表"xyz"包含连接两个表的"users_id"列.显然,"users_id"是"用户"表的"id"列.
现在出现的问题是我想在"users"表(很容易完成)和"xyz"表中同时插入数据.该User::create()函数将轻松创建用户数据并且它也正常工作但是为了在"xyz"表中插入数据,我将需要"user_id"列数据,并且在创建用户之前不会生成ID,因为ID列具有Auto-增量属性已激活.
码:
$user = new User;
$inputArry = array('data1' => $request['field1'],
'data2' => $request['field2'],
'data3' => $request['field3'],
);
$user->create($inputArry);
$user->xyz()->create([
'user_id' => $user->id,
'name' => $request['name'],
'about' => $request['desc'],
'tag' => $request['tag'],
]);
Run Code Online (Sandbox Code Playgroud)
以上是我为此目的使用的代码,但它给了我一个错误.
错误:
QueryException in Connection.php line 761:
SQLSTATE[23000]: Integrity constraint violation: 1048 Column 'soft_id' cannot be null (SQL: insert into `xyz` (`user_id`, `name`, `about`, `tag`, `updated_at`, `created_at`) values (, John, I am John, dev, 2016-11-09 21:01:29, 2016-11-09 21:01:29))
Run Code Online (Sandbox Code Playgroud)