简体   繁体   English

如何在hibernate中通过ArrayList保存多个对象?

[英]How to save multiple objects via ArrayList in hibernate?

I have a Student entity.我有一个学生实体。 My idea is to collect multiple student objects in an ArrayList and save all objects from that list to the database.我的想法是在 ArrayList 中收集多个学生对象,并将该列表中的所有对象保存到数据库中。 When do you use @ElementCollection annotation?什么时候使用@ElementCollection 注解? Does it apply to situations like this?它适用于这样的情况吗?

Student :学生

package basic;

import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;

@Entity
public class Student {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private int id;
    private String name;

    public Student() {

    }

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    @Override
    public String toString() {
        return "Student [id=" + id + ", name=" + name + "]";
    }

    public Student(String name) {
        this.name = name;
    }

}

Runner :亚军

package basic;

import java.util.ArrayList;
import java.util.List;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;

public class Runner {

    public static void main(String[] args) {

        SessionFactory sessionFactory = new Configuration().configure("/basic/hibernate.cfg.xml").buildSessionFactory();
        Session session = sessionFactory.openSession();
        session.beginTransaction();

        List<Student> students = new ArrayList<>();

        students.add(new Student("Michael"));
        students.add(new Student("Dave"));
        students.add(new Student("Tom"));
        students.add(new Student("Dinesh"));
        students.add(new Student("Lakshman"));
        students.add(new Student("Cruise"));

        session.save(students);

        session.getTransaction().commit();
        session.close();
    }

}

Error错误

Exception in thread "main" org.hibernate.MappingException: Unknown entity: java.util.ArrayList
    at org.hibernate.metamodel.internal.MetamodelImpl.entityPersister(MetamodelImpl.java:620)
    at org.hibernate.internal.SessionImpl.getEntityPersister(SessionImpl.java:1596)
    at org.hibernate.event.internal.AbstractSaveEventListener.saveWithGeneratedId(AbstractSaveEventListener.java:104)
    at org.hibernate.event.internal.DefaultSaveOrUpdateEventListener.saveWithGeneratedOrRequestedId(DefaultSaveOrUpdateEventListener.java:192)
    at org.hibernate.event.internal.DefaultSaveEventListener.saveWithGeneratedOrRequestedId(DefaultSaveEventListener.java:38)
    at org.hibernate.event.internal.DefaultSaveOrUpdateEventListener.entityIsTransient(DefaultSaveOrUpdateEventListener.java:177)
    at org.hibernate.event.internal.DefaultSaveEventListener.performSaveOrUpdate(DefaultSaveEventListener.java:32)
    at org.hibernate.event.internal.DefaultSaveOrUpdateEventListener.onSaveOrUpdate(DefaultSaveOrUpdateEventListener.java:73)
    at org.hibernate.internal.SessionImpl.fireSave(SessionImpl.java:668)
    at org.hibernate.internal.SessionImpl.save(SessionImpl.java:660)
    at org.hibernate.internal.SessionImpl.save(SessionImpl.java:655)
    at basic.Runner.main(Runner.java:27)

You have to do something like this: 你必须做这样的事情:

for(Student student : students) {
    session.save(student);
}

If you want to save entity you should map it. 如果要保存实体,则应映射它。 ArrayList<> is not mapped entity. ArrayList <>不是映射实体。 Student has mapping so you should save it separately. 学生有映射,所以你应该单独保存。

@ElementCollection you should use to define relation between object - here you have nice explenation https://en.wikibooks.org/wiki/Java_Persistence/ElementCollection @ElementCollection你应该用来定义对象之间的关系 - 这里你有很好的explenation https://en.wikibooks.org/wiki/Java_Persistence/ElementCollection

To save list of object, you need to iterate by objects, something like this -> How to insert multiple rows into database using hibernate? 要保存对象列表,需要按对象进行迭代,如下所示 - > 如何使用hibernate将多行插入数据库?

Any Functions that we can store an array of objects at once rather than using loops.我们可以一次存储对象数组而不是使用循环的任何函数。 This is causing performance issues..这会导致性能问题..

I would further recommend to use another Hibernate command to avoid an Out Of Memory error...我会进一步建议使用另一个 Hibernate 命令来避免Out Of Memory错误...

SessionFactory sessionFactory = config.buildSessionFactory();
    Session session = sessionFactory.openSession();
     
    Transaction transaction = session.beginTransaction();
     
    for (int i = 0 ; i < students.size(); i++) {
         session.save(students.get(i));
         
        if (i % 100 == 0) {//a batch size for safety
            session.flush();
            session.clear();
        }
    }
     
    transaction.commit();
    session.close();
    sessionFactory.close();

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM