栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

如何保留大量实体(JPA)

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

如何保留大量实体(JPA)

JPA API并未为您提供最佳选择。根据您要执行此操作的速度,您将不得不寻找特定于ORM的选项-在您的情况下为休眠状态。

检查事项:

  1. 检查您是否正在使用单笔交易(是的,显然您对此有把握)
  2. 检查您的JPA提供程序(Hibernate)是否正在使用JDBC批处理API(请参阅:hibernate.jdbc.batch_size)
  3. 检查是否可以绕过获取生成的密钥(取决于db / jdbc驱动程序,您从中获得多少好处-请参阅:hibernate.jdbc.use_getGeneratedKeys)
  4. 检查您是否可以绕过级联逻辑(这样做只能带来最小的性能收益)

因此,在Ebean ORM中,这将是:

    EbeanServer server = Ebean.getServer(null);    Transaction transaction = server.beginTransaction();    try {        // Use JDBC batch API with a batch size of 100        transaction.setBatchSize(100);        // Don't bother getting generated keys        transaction.setBatchGetGeneratedKeys(false);        // Skip cascading persist         transaction.setPersistCascade(false);        // persist your beans ...        Iterator<YourEntity> it = null; // obviously should not be null         while (it.hasNext()) { YourEntity yourEntity = it.next(); server.save(yourEntity);        }        transaction.commit();    } finally {        transaction.end();    }

哦,如果您通过原始JDBC执行此操作,则会跳过ORM开销(减少了对象创建/垃圾收集等操作),因此我不会忽略该选项。

因此,是的,这不能回答您的问题,但可以帮助您搜索更多针对ORM的特定批量插入调整。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/498094.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号