给定下一个数组,代表Page model:
[
"en" => [
"title": "Hello world",
"content": "Lorem ipsum ...",
"keyphrases": [
"Key phrase 1",
"Key phrase 2"
]
],
"es" => [
"title": "Hola Mundo",
"content": "Lorem ipsum ...",
"keyphrases": [
"Frase clave 1",
"Frase clave 2"
]
]
]
使用Page::create(...)
将创建&保存新的页面记录到数据库,但关键短语存储在不同的表中(并由“Keyphrase”模型表示),所以我尝试使用Page::create(...)->keyphrases()->create($request->all())
但它没有不行,因为创建方法只创建一个实例,正如我所理解的那样。
考虑到我的数据被分成语言,在数据库中大量创建“关键短语”的最佳方法是什么?
我认为这不重要,但我使用dimsav/laravel-translations
答案 0 :(得分:1)
不确定您希望如何存储关键短语。但这是一个很好的例子。
/*[
[
"Key phrase 1",
"Key phrase 2"
],
[
"Frase clave 1",
"Frase clave 2"
]
]*/
$keyPhrases = array_column($data, 'keyphrases');
$page = Page::create(...);
$page->keyphrases()->insert($keyPhrases);
答案 1 :(得分:1)
我会使用循环来插入多个记录。另一种方法是将请求数组拆分为一个数组,该数组包含设置表的不同列的子数组。喜欢这个
//Modify the data so that the sturcture is as $keyhrases
$keyhrases = array( [ 'keyphrase' => 'Foo' ], [ 'keyphrase' => 'Bar' ], etc );
$page->keyphrases()->insert($keyhrases);
但是,修改数组比简单的for循环更重要。