首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Golang并发把excel数据插入到数据库

= nil { return } _, err = io.Copy(localFile, res.Body) //把body里的内容复制到本地excel文件 if err !...每次批量插入100条数据到数据库 func InsertBatch(temp [][]string, length int) error { db := modelUtils.GetDB() //gorm...= nil { return err } return nil } 3.并发调用 每100个批量插入就放进channel中成为一个缓存,channel的缓存大小为50,每50个channel开启一个...最终结果: 大概有40多万条数据,每5000条数据一个goroutine,那么大概需要80多个goroutine,总共花费的时间大概是1分钟,因为阿里云服务器为2核4G的性能,所以主要的性能瓶颈在于服务器上的数据库...,虽然开启的数据库池,但是单条数据的插入时间是固定的 我还试了一下把同样40多万的数据插入到亚马逊云的数据库,要16分钟左右,因为服务器在国外,所以受网络影响较大 image.png

2.9K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    thinkphp5.1中无法插入数据到数据库

    资料,PHP中文网think PHP5.1视频 今天的解决的问题困扰了我几天了,期间问舍友也是没有搞清楚原理,现在回想起来,一部分的原因或许是hubilder的问题...,暂时不清楚,但是今天我换成sublime text后验证器什么的都运行正常了,然而在注册数据插入数据库的地方还是会报500的错误。...试了很多方法都不成功,期间舍友带着我将model.php文件里的insert方法和insert方法衍生出来的方法都看了,但是还是没有解决好。。。...后面就想着request::post到的数据可以在控制台输出,那我就重写一个数组赋值上去,然后调用Db::table这样的类型将数据插入进数据库中,但随后又发现验证器什么的都没有用了,逻辑混乱·····...发现问题所在,基本就是数据库表和request回的数组不匹配的原因吧。。。

    1.9K10

    180710-MySql插入唯一键冲突的三种可选方式

    MySql插入时唯一键冲突的几种处理方式 MySql插入一条记录,结果提示主键冲突,怎么办?...批量插入数据时,发现插入的这批数据中,有某些记录存在唯一键冲突,一个一个跳出来就比较麻烦了,有什么好的办法直接忽略掉冲突的记录么? 下面简单记录三种处理方式 I....Ignore关键词 某些场景下,我们需要批量插入的数据,某些已经在DB中了,因此我希望在出现冲突时,直接跳过,把能插入的都插入就好,这种情况下,使用ignore关键词就比较合适了 一个实际的case如下...Replace Into方式 如果在批量插入中,存在冲突时,我希望用我的新数据替换旧的数据,这个时候就可以使用replace into了 常用姿势如下 replace into `user` (`id`...value, 比如上面的插入中,当冲突时,我们只更新update_at字段,而name的test0没有更新 II.

    1.3K20

    盘点一个通过python大批量插入数据到数据库的方法

    一、前言 前几天在Python白银群【鶏啊鶏】问了一个Python数据存入数据库的问题,一起来看看吧。...各位大佬 我想请教下通过python大批量插入数据到数据库的方法 目前我在用的操作是以下这个模式: sql='' for i in list: sql = "insert XXX表(地址,单号,缸号,...状态,备注,时间) values('" + address + "','"+ppo+"','"+batch_no+"','待定','未生产',getdate())" 这样当sql稍微大点的情况下 一次性插入就会插入失败...,想请问下各位大佬如果大批量插入的话应该用哪个方式更稳定点呢。...顺利地解决了粉丝的问题。 三、总结 大家好,我是皮皮。这篇文章主要盘点了一个Python数据存数据库的问题,文中针对该问题,给出了具体的解析和代码实现,帮助粉丝顺利解决了问题。

    49430

    pdf格式的图片如何插入到word中

    然后就开始了我一系列的折腾。 废话1 有一个百度经验,竟然是把pdf打开,然后用截图软件截图为png,然后直接复制粘贴到word中。截图的清晰度不好,效果类似: ?...废话2 将pdf复制到word中,双击pdf的图标就可以打开pdf…… ? 操作失败3 据说,word中可以直接插入pdf 「插入 ---> 对象 ----> 对象」 ?...背景我没有找到去掉的方法,所以没有搞定。...吐槽4 我想着pdf的图片,加到论文中,这不应该是一个常规的操作么,为何我没有找到合适的方法呢,是没有写过论文的缘故吗…… 搞定5 既然无法直接插入pdf图片,那就把pdf转化为其它格式吧。...转化为JPG的格式如下: ? 放大一点,也没有失真: ? 如果是直接从R中导出的png文件,放大后失真: ? 真香6 将pdf转化为png的图片,粘贴到word中,搞定!

    4.1K10

    Prometheus时序数据库-数据的插入

    前言 在之前的文章里,笔者详细的阐述了Prometheus时序数据库在内存和磁盘中的存储结构。有了前面的铺垫,笔者就可以在本篇文章阐述下数据的插入过程。...监控数据的插入 在这里,笔者并不会去讨论Promtheus向各个Endpoint抓取数据的过程。而是仅仅围绕着数据是如何插入Prometheus的过程做下阐述。...add到memSeries(也就是query所用到的结构体里),而是加入到一个临时的samples切片里面。...最终落地是通过compator routine将每两个小时的数据打包到一个Blocks里面。...具体可见笔者之前的博客《Prometheus时序数据库-磁盘中的存储结构》 总结 在这篇文章里,笔者详细描述了Prometheus数据的插入过程。

    1.5K00

    数据库批量插入这么讲究的么?

    测试环境: SpringBoot 2.5 Mysql 8 JDK 8 Docker 首先,多条数据的插入,可选的方案: foreach循环插入 拼接sql,一次执行 使用批处理功能插入 搭建测试环境`...不同的测试 1. foreach 插入 先获取列表,然后每一条数据都执行一次数据库操作,插入数据: @SpringBootTest @MapperScan("com.aphysia.springdemo.mapper...运行上面的代码,我们可以得到下面的结果,for循环插入的效率确实很差,拼接的sql效率相对高一点,看到有些资料说拼接sql可能会被mysql限制,但是我执行到1000w的时候,才看到堆内存溢出。...驱动在默认情况下会忽视 executeBatch() 语句,我们期望批量执行的一组 sql 语句拆散,但是执行的时候是一条一条地发给 MySQL 数据库,实际上是单条插入,直接造成较低的性能。...正确的数据库连接: jdbc:mysql://127.0.0.1:3306/test?

    96120

    数据库批量插入这么讲究的么?

    测试环境: SpringBoot 2.5 Mysql 8 JDK 8 Docker 首先,多条数据的插入,可选的方案: foreach循环插入 拼接sql,一次执行 使用批处理功能插入 1搭建测试环境...2不同的测试 1. foreach 插入 先获取列表,然后每一条数据都执行一次数据库操作,插入数据: @SpringBootTest @MapperScan("com.aphysia.springdemo.mapper...运行上面的代码,我们可以得到下面的结果,for循环插入的效率确实很差,拼接的sql效率相对高一点,看到有些资料说拼接sql可能会被mysql限制,但是我执行到1000w的时候,才看到堆内存溢出。...驱动在默认情况下会忽视 executeBatch() 语句,我们期望批量执行的一组 sql 语句拆散,但是执行的时候是一条一条地发给 MySQL 数据库,实际上是单条插入,直接造成较低的性能。...正确的数据库连接: jdbc:mysql://127.0.0.1:3306/test?

    93420

    mysql将数据表插入到另一个数据库的表

    在MySQL中,如果你想要将一个数据库中的数据表插入到另一个数据库的表中,可以使用`INSERT INTO ... SELECT`语句;或者复制粘贴的方案。...SELECT`语句**:此语句允许你从一个或多个表中选取数据,并将其插入到另一个表中。 1.2 经典例子 假设你有两个数据库,`source_db`和`target_db`。...-- 假设source_table和target_table有相同的字段:id, name, age -- 将source_db.source_table中的数据插入到target_db.target_table...方案2 复制粘贴 2.1 先查询想要迁移的数据数据 2.2 Ctrl+A,右键复制insert语句 2.3 放到记事本修改 修改数据库名称db_kingform_dev(如果是同一个数据库里面就不用修改...) 2.4 到目标库执行sql 新建查询,然后选中运行整段代码即可。

    30110

    教你88秒插入1000万条数据到mysql数据库表

    我用到的数据库为,mysql数据库5.7版本的 首先自己准备好数据库表 其实我在插入1000万条数据的时候遇到了一些问题,现在先来解决他们,一开始我插入100万条数据时候报错,控制台的信息如下: com.mysql.jdbc.PacketTooBigException...出现上面的错误是因为数据库表的 max_allowed_packet 这个配置没配置足够大,因为默认的为4M的,后来我调为100M就没报错了 set global max_allowed_packet...= 100*1024*1024* 记住,设置好后重新登录数据库才能看的设置后的值 show VARIABLES like '%max_allowed_packet%' 代码如下: package insert...结束时间 Long end = new Date().getTime(); // 耗时 System.out.println( "1000万条数据插入花费时间...: " + (end - begin) / 1000 + " s" ); System.out.println( "插入完成" ); } }

    1.8K40
    领券