Java多线程Jdbc_java – 关于在jdbc中使用多线程的教程

多线程将提高您的性能,但您需要知道几件事情:

>每个线程都需要自己的JDBC连接.线程之间无法共享连接,因为每个连接也是一个事务.

>以数据块的形式上传数据,一次提交一次,以避免累积大量的回滚/撤销表.

>将任务切成几个单位,每个单位做一个工作.

要阐述最后一点:目前,您有一个任务读取文件,解析它,打开JDBC连接,进行一些计算,将数据发送到数据库等.

你应该做什么

>一个(!)线程读取文件并创建“作业”.每个工作都应该包含一个小的但不是太小的“工作单位”.将它们推入队列

>下一个线程等待队列中的作业并进行计算.这可能会发生在步骤#1中的线程等待慢硬盘返回新的数据行.此转换步骤的结果进入下一个队列

>通过JDBC上传数据的一个或多个线程.

第一个和最后一个线程相当慢,因为它们是I / O绑定(硬盘缓慢,网络连接更糟).加入数据库中的数据是一个非常复杂的任务(分配空间,更新索引,检查外键)

使用不同的工作线程可以提供很多优点:

>单独测试每个线程很容易.由于他们不共享数据,您不需要同步.队列会为你做这个>您可以快速更改每个步骤的线程数以调整性能

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值