oracle 插入表太慢,JPA使用对象图表插入速度慢

我正在尝试使用JPA对大型对象图进行级联保存.例如(我的对象图有点大但足够接近):

@Entity

@Table(name="a")

public class A {

private long id;

@OneToMany(cascade = CascadeType.ALL, mappedBy = "a")

private Collection bs;

}

@Entity

@Table(name="b")

public class B {

private long id;

@ManyToOne

private A a;

}

所以我试图坚持A有100 B的集合.代码就是

em.persist(a);

问题是,它很慢.我的节省大约需要1300毫秒.我查看了生成的SQL,它非常低效.像这样的东西:

select a_seq.nextval from dual;

select b_seq.nextval from dual;

select b_seq.nextval from dual;

select b_seq.nextval from dual;

...

insert into a (id) values (1);

insert into b (id, fk) values (1, 1);

insert into b (id, fk) values (2, 1);

insert into b (id, fk) values (3, 1);

...

目前使用toplink作为持久性提供程序,但我也尝试过eclipselink和hibernate.后端是oracle 11g.问题实际上是如何将sql放在一起.这些操作中的每一个都是分散完成而不是批量完成,因此如果我的appserver和db服务器之间的网络延迟甚至达到5ms,那么执行200次离散操作会增加1秒.我已经尝试过增加我的序列的allocationSize,但这只会有所帮助.我也尝试过直接JDBC作为批处理语句:

for...{

statement = connection.prepareStatement(sql);

statement.addBatch();

}

statement.executeBatch();

对于我的datamodel,它需要大约33ms作为直接JDBC批处理.对于100个插入,Oracle本身需要5毫秒.

无论如何制作JPA(我现在正在坚持使用1.0),如果没有深入研究像hibernate批量插入这样的供应商特定的事情,那就更快了吗?

谢谢!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值