Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/331.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 如何使用hibernate将多行插入数据库?_Java_Hibernate - Fatal编程技术网

Java 如何使用hibernate将多行插入数据库?

Java 如何使用hibernate将多行插入数据库?,java,hibernate,Java,Hibernate,我正在循环列表并插入数据库,但它会一个接一个地更新记录。最后,我在数据库中只看到列表的最后一条记录 输入名称:Linux、windows、mac Session session = (Session) HibernateUtil.getSessionFactory().openSession(); String[] items = pi.getNewLicenseName().split(","); for (String item : items) { feature.setName(item

我正在循环列表并插入数据库,但它会一个接一个地更新记录。最后,我在数据库中只看到列表的最后一条记录

输入名称:Linux、windows、mac

Session session = (Session) HibernateUtil.getSessionFactory().openSession();
String[] items = pi.getNewLicenseName().split(",");
for (String item : items)
{
feature.setName(item);
session.save(feature);
}
 session.getTransaction().commit();
 HibernateUtil.shutdown();
hibernate.cfg.xml:

<hibernate-configuration>

    <session-factory>


    <property name="connection.driver_class">com.microsoft.sqlserver.jdbc.SQLServerDriver</property>
    <property name="connection.url">jdbc:sqlserver://******</property>
    <property name="connection.username">*****</property>
    <property name="connection.password">*****</property>

    <property name="dialect">org.hibernate.dialect.SQLServerDialect</property>


        <property name="cache.provider_class">org.hibernate.cache.internal.NoCacheProvider</property>

        <property name="hibernate.current_session_context_class">thread</property>
<property name="hibernate.current_session_context_class">org.hibernate.context.internal.ThreadLocalSessionContext</property>


        <property name="show_sql">true</property>
<property name="hibernate.hbm2ddl.auto">update</property>

        <!-- Names the annotated entity class -->

         <mapping class="com.DAO.Feature"/>

    </session-factory>

请帮助我将多行插入数据库。

有一个非常好的章节

设置属性

hibernate.jdbc.batch_size 20
然后使用这个代码

Session session = sessionFactory.openSession();
Transaction tx = session.beginTransaction();

for ( int i=0; i<100000; i++ ) {
    Customer customer = new Customer(.....);
    session.save(customer);
    if ( i % 20 == 0 ) { //20, same as the JDBC batch size
        //flush a batch of inserts and release memory:
        session.flush();
        session.clear();
    }
}

tx.commit();
session.close();
Session Session=sessionFactory.openSession();
事务tx=会话.beginTransaction();
对于会话中使用
save()
方法的(int i=0;i),Hibernate将对象耦合到一行,并且在会话保持活动状态时此关系保持不变。因此,如果使用同一对象,则实际上会更新现有行。解决方案是为每一行构造一个新对象。在这种情况下:

for (String item : items)
{
  Feature feature = new Feature();
  feature.setName(item);
  session.save(feature);
}

太好了,非常感谢。Hibernate之所以将您提出的解决方案称为“幼稚方法”(请参阅我答案中的文档链接)。您真的不应该这样做……您是对的,但问题更多的是为什么只进行一次插入,而不是如何进行批量更新。对于那些想知道为什么这是一种“幼稚方法”的人来说,对于一个非常大的数组,您可能会遇到OutOfMemoryException:“这将在第50000行的某个位置发生OutOfMemoryException。这是因为Hibernate会在会话级缓存中缓存所有新插入的
功能
实例。在本章中,我们将向您展示如何避免此问题。”()
for (String item : items)
{
  Feature feature = new Feature();
  feature.setName(item);
  session.save(feature);
}
session.merge(object);
session.flush();
session.clear();