Форум программистов, компьютерный форум, киберфорум
Java EE (J2EE)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/15: Рейтинг темы: голосов - 15, средняя оценка - 4.67
14 / 14 / 2
Регистрация: 03.02.2010
Сообщений: 142

Hibernate: cannot simultaneously fetch multiple bags

14.07.2012, 15:09. Показов 2921. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте! Я пишу программу, где используется Hibernate. У меня есть пять персистентных классов, реализующих таблицы:

1) Это класс Post (Список Должностей)
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
import java.util.List;
 
import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.OneToMany;
 
@Entity
public class Post {
    @Id
    @GeneratedValue
    @Column(name="post_id")
    public int getId() {
        return id;
    }
    public void setId(int id) {
        this.id = id;
    }
    
    @Column(name="post_name")
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    
    @OneToMany(targetEntity=EmployeeHistory.class,mappedBy="post",
            cascade=CascadeType.ALL,fetch=FetchType.EAGER)
    public List<EmployeeHistory> getEmployeeHistories() {
        return employeeHistories;
    }
    public void setEmployeeHistories(List<EmployeeHistory> employeeHistories) {
        this.employeeHistories = employeeHistories;
    }
    
    private int id;
    private String name;
    List<EmployeeHistory> employeeHistories;
}
2) Класс Person (Список людей)
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
import java.util.List;
 
import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.OneToMany;
 
@Entity
public class Person {
    
    @Id
    @GeneratedValue
    @Column(name="person_id")
    public int getId() {
        return id;
    }
 
    public void setId(int id) {
        this.id = id;
    }
 
    @Column(name="person_name")
    public String getName() {
        return name;
    }
    
    public void setName(String name) {
        this.name = name;
    }
    
    @Column(name="person_lost_name")
    public String getLostName() {
        return lostName;
    }
    public void setLostName(String lostName) {
        this.lostName = lostName;
    }
    public String getPatronym() {
        return patronym;
    }
    public void setPatronym(String patronym) {
        this.patronym = patronym;
    }
    
    @OneToMany(targetEntity=EmployeeHistory.class,mappedBy="person",
            cascade=CascadeType.ALL,fetch=FetchType.EAGER)
    public List<EmployeeHistory> getEmployeeHistories() {
        return employeeHistories;
    }
 
    public void setEmployeeHistories(List<EmployeeHistory> employeeHistories) {
        this.employeeHistories = employeeHistories;
    }
 
 
    private int id;       //первичный ключ
    private String name,  //имя 
           lostName,  //фамилия
           patronym; //отчество
    
    List<EmployeeHistory> employeeHistories;
}
3) Класс Division (список подразделений компании)
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
import java.util.List;
 
import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.OneToMany;
 
@Entity
public class Division {
    
    @Id
    @GeneratedValue
    @Column(name="div_id")
    public int getId() {
        return id;
    }
    public void setId(int id) {
        this.id = id;
    }
    
    @Column(name="div_name")
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    
    @OneToMany(targetEntity=DivHistory.class,mappedBy="division",
            cascade=CascadeType.ALL,fetch=FetchType.EAGER)
    public List<EmployeeHistory> getEmployeeHistories() {
        return employeeHistories;
    }
    public void setEmployeeHistories(List<EmployeeHistory> employeeHistories) {
        this.employeeHistories = employeeHistories;
    }
    
    @OneToMany(targetEntity=DivHistory.class,mappedBy="division",
            cascade=CascadeType.ALL,fetch=FetchType.EAGER)
    public List<DivHistory> getDivHistories() {
        return divHistories;
    }
    public void setDivHistories(List<DivHistory> divHistories) {
        this.divHistories = divHistories;
    }
 
    private int id;      //певичный ключ
    private String name; //имя
    
    List<EmployeeHistory> employeeHistories; //записи о работниках
    List<DivHistory> divHistories;  //записи о подразделениях
}
4) В классе EmployeeHistory хранится информация о том, когда (какого числа) какой сотрудник получил такую-то должность или когда перешёл в такое-то подразделение. Иными словами, записывает все изменения связанные с сотрудниками.
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
import java.util.Date;
 
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.Table;
 
@Entity
@Table(name="employee_history")
public class EmployeeHistory {
    
    @Id
    @GeneratedValue
    @Column(name="emp_history_id")
    public int getId() {
        return id;
    }
    public void setId(int id) {
        this.id = id;
    }
    
    @Column(name="emp_date")
    public Date getDate() {
        return date;
    }
    public void setDate(Date date) {
        this.date = date;
    }
    
    @ManyToOne
    @JoinColumn(name="person_id")
    public Person getPerson() {
        return person;
    }
    public void setPerson(Person person) {
        this.person = person;
    }
    
    @ManyToOne
    @JoinColumn(name="post_id")
    public Post getPost() {
        return post;
    }
    public void setPost(Post post) {
        this.post = post;
    }
    
    @ManyToOne
    @JoinColumn(name="div_id")
    public Division getDivision() {
        return division;
    }
    public void setDivision(Division division) {
        this.division = division;
    }
    
    private int id;//emp_change_id
    Date date;//div_date
    
    private Person person;
    private Post post;
    private Division division;  
}
5) В классе DivHistory хранится когда подразделение id стало входить в подразделение fathId (father id)
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
import java.util.Date;
 
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.Table;
 
@Entity
@Table(name="div_hisory")
public class DivHistory {
 
    @Id
    @GeneratedValue
    @Column(name="div_change_id")
    public int getId() {
        return id;
    }
 
    public void setId(int id) {
        this.id = id;
    }
 
    @Column(name="father_div_id")
    public int getFathId() {
        return fathId;
    }
 
    public void setFathId(int fathId) {
        this.fathId = fathId;
    }
 
    @Column(name="div_date")
    public Date getDate() {
        return date;
    }
 
    public void setDate(Date date) {
        this.date = date;
    }
    
    @ManyToOne
    @JoinColumn(name="div_id")
    public Division getDivision() {
        return division;
    }
    
    public void setDivision(Division division) {
        this.division = division;
    }
    
 
    private int id,//div_change_id
            fathId;//father_div_id
    Date date;//div_date
    Division division;
 
}
И есть ещё класс DBManager, управляющий всем этим.

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
import org.hibernate.tool.hbm2ddl.SchemaExport;
 
public class DBManager {
 
    public DBManager() {
        config=new Configuration();
        config.addAnnotatedClass(DivHistory.class);
        config.addAnnotatedClass(Division.class);
        config.addAnnotatedClass(EmployeeHistory.class);
        config.addAnnotatedClass(Person.class);
        config.addAnnotatedClass(Post.class);
        
        config.configure(constConfig);
        //new SchemaExport(config).create(true, true);
        
//      SessionFactory factory=config.buildSessionFactory();
//      session=factory.getCurrentSession();
    }
    
    public Session getCurrentSession()
    {
        SessionFactory factory=config.buildSessionFactory();
        return factory.getCurrentSession();
    }
    
    public void init()
    {
        new SchemaExport(config).create(true, true);
    }
    
    public void addPerson(Person person,Post post,Division division) 
    {
        Session session=this.getCurrentSession();
        session.beginTransaction();//начало транзакции
        
        EmployeeHistory eh=new EmployeeHistory();
        
        eh.setPerson(person);
        eh.setPost(post);
        eh.setDivision(division);
        
        session.save(eh);
        session.save(person);
        session.getTransaction().commit();
    }
    
    public void addEmployee(String name,String surname, String patronym,
            String post, String division) 
    {
        
    }
    
    public void addDivision(Division division, int fathId)
    {
        Session session=this.getCurrentSession();
        session.beginTransaction();//начало транзакции
        
        DivHistory dh=new DivHistory();
        
        dh.setDivision(division);
        dh.setFathId(fathId);
        
        session.save(dh);
        session.save(division);
        
        session.getTransaction().commit();
    }
    
    public void addPost(Post post)
    {
        Session session=this.getCurrentSession();
        session.beginTransaction();//начало транзакции
        
        session.save(post);
        
        session.getTransaction().commit();
    }
    
    public static void main(String[] args) 
    {
        DBManager manager=new DBManager();
        manager.init();
        Post post=new Post();
        post.setName("Administrator");
        manager.addPost(post);
//      Division div=new Division();
//      manager.addDivision(div, 13);
//      Person person=new Person();
//      person.setName("Nikolay");
//      person.setLostName("Stavrogin");
//      person.setPatronym("Vselodovich");
//      manager.addPerson(person, post, div);
    }
    
    Configuration config;
    private final static String constConfig="hibernate.cfg.xml";
}
Все действия описаны в методе main() класса DBManager.

Все таблицы благополучно создаются, код конструктора класса и метод init() работаю без ошибок. Но при попытке добавить новую запись возникает ошибка "cannot simultaneously fetch multiple bags".
Трассировка ошибки, выглядит следующим образом:
Exception in thread "main" org.hibernate.loader.MultipleBagFetchExc eption: cannot simultaneously fetch multiple bags
at org.hibernate.loader.BasicLoader.postIns tantiate(BasicLoader.java:94)
at org.hibernate.loader.entity.EntityLoader .<init>(EntityLoader.java:119)
at org.hibernate.loader.entity.EntityLoader .<init>(EntityLoader.java:71)
at org.hibernate.loader.entity.EntityLoader .<init>(EntityLoader.java:54)
at org.hibernate.loader.entity.BatchingEnti tyLoader.createBatchingEntityLoader(Batc hingEntityLoader.java:133)
at org.hibernate.persister.entity.AbstractE ntityPersister.createEntityLoader(Abstra ctEntityPersister.java:1914)
at org.hibernate.persister.entity.AbstractE ntityPersister.createEntityLoader(Abstra ctEntityPersister.java:1937)
at org.hibernate.persister.entity.AbstractE ntityPersister.createLoaders(AbstractEnt ityPersister.java:3206)
at org.hibernate.persister.entity.AbstractE ntityPersister.postInstantiate(AbstractE ntityPersister.java:3192)
at org.hibernate.persister.entity.SingleTab leEntityPersister.postInstantiate(Single TableEntityPersister.java:728)
at org.hibernate.impl.SessionFactoryImpl.<i nit>(SessionFactoryImpl.java:348)
at org.hibernate.cfg.Configuration.buildSes sionFactory(Configuration.java:1872)
at com.java.summwork.dbwork.DBManager.getCu rrentSession(DBManager.java:27)
at com.java.summwork.dbwork.DBManager.addPo st(DBManager.java:76)
at com.java.summwork.dbwork.DBManager.main( DBManager.java:90)
У меня есть подозрения, что это связано с моими попытками маппинга @OneToMany в классе EmployeeHistory, но может это и не так.

В чём может быть эта ошибка? Есть ли способ её как-дибо разрешить?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
14.07.2012, 15:09
Ответы с готовыми решениями:

Spring. Hibernate. Multiple representations of the same entity
Добрый день Имею следующий маппинг Person import javax.persistence.*; import java.io.Serializable; import...

JPA/Hibernate @OneToOne@OneToOne(fetch = FetchType.LAZY) не работает
Здравствуйте. Пишу дипломный проект, после проверки получил замечание что в моём случае lazy не будет работать. Вопрос что не так? ...

Hibernate и аннотация @ManyToMany(fetch=FetchType.EAGER)
И так , добрый день! Сразу к делу. Имеем две модели данных связанные между собой аннотацией @ManyToMany @Entity @Table(name =...

3
 Аватар для mutagen
2587 / 2260 / 257
Регистрация: 14.09.2011
Сообщений: 5,185
Записей в блоге: 18
14.07.2012, 15:19
смените employeeHistories на Set и примари кей лучше long
или
Java
1
@Fetch(value = FetchMode.SUBSELECT)
1
14 / 14 / 2
Регистрация: 03.02.2010
Сообщений: 142
14.07.2012, 15:45  [ТС]
Спасибо, действительно помогло.

Возникла другая ошибка другого рода. Когда я выполняю такой код:
Java
1
2
3
4
5
6
7
8
9
10
11
DBManager manager=new DBManager();
manager.init();
//добавляем должность
Post post=new Post();
post.setName("Administrator");
manager.addPost(post);
 
//добавляем подразделение
Division div=new Division();
div.setName("DivName1");
manager.addDivision(div, 13);
То почему-то должность стирается и таблица Post оказывается пустой.
0
 Аватар для mutagen
2587 / 2260 / 257
Регистрация: 14.09.2011
Сообщений: 5,185
Записей в блоге: 18
14.07.2012, 16:02
почитайте про detached и про update в документации
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
14.07.2012, 16:02
Помогаю со студенческими работами здесь

получить все записи из <select multiple='multiple'
как через JQUERY получить все записи из &lt;select multiple='multiple'

Hibernate Could not get constructor for org.hibernate.persister.entity.SingleTableEntityPersister
Доброго времени суток. Сталкиваюсь со всякими ошибками при добавлении данных в свою mysql бд. Вот код ошибки Exception in thread...

Fetch Request
Доброго времени суток Подскажите пожалуйста, как вывести результат Fetch Request на экран?

Ajax fetch
есть в php функция которая данные кодирует в json и ложит в переменую как обратится с помошью fetch к этой переменой в интернете искал...

Непонятки с Fetch
Народ, в чем может быть проблема! Когда запускаю запрос из жабы для получения дбф-ника - отлично все шпарит - получаю то что нада, когда...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru