laravel-admin1.8第二讲,导入按钮

依赖

导入基本上都是excel进行导入,所以我们需要使用excel的相关依赖,大家可以使用自己熟悉的,我是按照我熟悉的依赖。

composer require maatwebsite/excel

在这里插入图片描述

创建导入按钮

php artisan admin:action Post\\ImportPost --name="导入数据"
App\Admin\Actions\Post\ImportPost created successfully.

也可以试着使用helpers执行命令。

我这里举一个例子,我们的数据结构是:

CREATE TABLE `dangan` (
  `id` int(10) UNSIGNED NOT NULL,
  `laiwendanwei` varchar(255) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
  `daizi` varchar(255) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
  `wenhao` varchar(255) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
  `nianfen` varchar(255) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
  `biaoti` varchar(255) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
  `qianfaren` varchar(255) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
  `mijidengji` varchar(255) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
  `shoufadate` varchar(255) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
  `yeshu` varchar(255) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
  `fenshu` varchar(255) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
  `beizhu` varchar(255) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
  `xuhao` varchar(255) COLLATE utf8mb4_unicode_ci DEFAULT NULL COMMENT '序号',
  `zhengwenneirong` text COLLATE utf8mb4_unicode_ci COMMENT '正文内容',
  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Laravel本身不支持多线程操作,但是可以通过使用PHP的多线程扩展来实现多线程操作。对于大量数据的导入,可以考虑使用队列来异步处理任务,以避免阻塞导致的性能瓶颈。 以下是一个基本的实现步骤: 1. 将Excel文件上传到服务器上; 2. 分割Excel文件成多个小文件; 3. 将每个小文件分配给一个独立的线程进行导入; 4. 使用队列来异步处理任务,以避免阻塞导致的性能瓶颈。 在实现多线程导入Excel文件的过程中,需要注意以下几点: 1. 在多线程之间共享数据时,需要使用锁机制来保证数据的一致性; 2. 在多线程中使用数据库时,需要注意数据库的并发访问; 3. 在多线程中出现异常时,需要及时捕获并处理异常。 以下是一个简单的示例代码: ```php //分割Excel文件,将每个小文件分配给一个独立的线程进行导入 public function importExcel() { $file = request()->file('file'); $path = $file->store('temp'); $excelData = Excel::toArray(new ExcelImport(), $path); $data = collect($excelData[0])->chunk(100); foreach ($data as $chunk) { dispatch(new ImportExcelJob($chunk)); } } //导入Excel文件的任务 class ImportExcelJob implements ShouldQueue { use Dispatchable, InteractsWithQueue, Queueable, SerializesModels; protected $data; public function __construct($data) { $this->data = $data; } public function handle() { foreach ($this->data as $row) { DB::table('table_name')->insert($row); } } } ``` 在这个示例中,我们首先将Excel文件分割成多个小文件,然后将每个小文件分配给一个独立的线程进行导入。具体地,我们使用Laravel的队列系统来异步处理任务,以避免阻塞导致的性能瓶颈。在导入Excel文件的任务中,我们使用Laravel内置的DB类来将数据插入到数据库中。需要注意的是,在多线程中操作数据库时,需要注意数据库的并发访问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

陈硕无敌

来吧,打赏我吧!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值