使用Laravel一次性插入多条记录

16

我正在逐一将数据插入行中,但我在某处听说如果有很多数据需要插入,逐一插入会花费很多时间。那么有什么方法可以一次性地将它们全部插入呢?

public function add(Request $request)
{
    if ($request->ajax()) {
        $books = $request->books;
        foreach ($books as $book) {
            if (!empty($book)) {
                $add = new Book;
                $add->name = $book;
                $add->user_id = Auth::user()->id;
                $add->save();
            }
        }
    }
}

这个旧问题可能会有所帮助,答案的最新评论链接到一些有用的内容。 - user5051310
(我不是 Laravel 开发者)看起来一年前的任何答案都不再相关了?我猜这取决于版本... - user5051310
5个回答

30
public function add(Request $request)
  {
    if($request->ajax())
    {
       $books=$request->books;
       $data = array();
       foreach($books as $book)
       {
        if(!empty($book))
        {
          $data[] =[
                    'name' => $book,
                    'user_id' => Auth::id(),
                   ];                 

       }}
      Book::insert($data);
       <!--DB::table('books')->insert($data);-->
     }}

确保导入了 use Illuminate\Support\Facades\Auth;


12

使用模型插入多条记录

正如其他人指出的那样,使用查询构建器是一次性插入多条记录的唯一方式。幸运的是,Laravel和Eloquent ORM有许多有用的耦合方式。这种耦合允许您使用一个模型来获取为该模型设置的查询构建器实例。

// use Auth;
// use Carbon;
// use App\Book;

public function add(Request $request)
{
    if($request->ajax())
    {
        // Submitted books
        $books = $request->books;

        // Book records to be saved
        $book_records = [];

        // Add needed information to book records
        foreach($books as $book)
        {
            if(! empty($book))
            {
                // Get the current time
                $now = Carbon::now();

                // Formulate record that will be saved
                $book_records[] = [
                    'name' => $book,
                    'user_id' => Auth::user()->id,
                    'updated_at' => $now,  // remove if not using timestamps
                    'created_at' => $now   // remove if not using timestamps
                ];
            }
        }

        // Insert book records
        Book::insert($book_records);
    }
}

6
很遗憾你发布了我的复制品 @Qevo。 - Hamelraj
请停止复制粘贴他人的解决方案。 - VijayRana

9
您应该能够像下面这样做:
DB::table('users')->insert([
    ['email' => 'taylor@example.com', 'votes' => 0],
    ['email' => 'dayle@example.com', 'votes' => 0]
]);

将想要插入的所有值存储到一个数组中,然后将该数组传递给插入函数。

来源:https://laravel.com/docs/5.1/queries#inserts


-1
foreach($request->refereename as $i =>$value)
  {
    $referees[]=[
        'refereename'=>$request->refereename[$i],
        'refereecompany'=>$request->refereecompany[$i],
        'refereephone'=>$request->refereephone[$i],
        'refereeemail'=>$request->refereeemail[$i],
        'relationship'=>$request->relationship[$i],
        'refereelocation'=>$request->refereelocation[$i],
        'created_at'=>$date,
        'updated_at'=>$date,
        ];
  }

  DB::table('db_referees')->insert($referees); // Query Builder approach 

1
你的回答可以通过提供更多支持性信息来改进。请编辑以添加进一步的细节,例如引用或文档,以便他人能够确认你的回答是否正确。你可以在帮助中心找到关于如何撰写好回答的更多信息。 - Community

-3

如果您需要使用Eloquent 模型事件 - 没有其他方法可以插入多个模型。否则,请查看Anushan W的答案。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接