С Новым годом! Форум программистов, компьютерный форум, киберфорум
Java EE (J2EE)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
0 / 0 / 2
Регистрация: 03.05.2017
Сообщений: 6

Java8, Hibernate5, MySQL, IdClass, ManyToOne, EntityExistsException - Halp!

07.02.2018, 15:09. Показов 833. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день!
Пытаюсь настроить связь приложения с базой данных, а именно:
есть две сущности, связанные между собой как ManyToOne по двум внешним ключам, описанным в отдельном IdClass.
При попытке сохранить в базу несколько сущностей, вываливается ошибка EntityExistsException - опытным путем выявлено, что при создании экземпляра сущности не генерируется автоинкрементный ключ - остается 0. Если задать ключи вручную, всё работает как надо.

Подскажите пожалуйста, где проблема.

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
import javax.persistence.*;
import java.util.Collection;
import java.util.Objects;
 
@Entity
@Table(name = "bot", schema = "mydb", catalog = "")
public class BotEntity {
    private int id;
    private String botKey;
    private String botName;
    private int botCreateDate;
    private Collection<UpdateEntity> updatesById;
 
    @Id
    @Column(name = "id")
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    public int getId() {
        return id;
    }
 
    public void setId(int id) {
        this.id = id;
    }
 
    //Getters, Setters, Hashcode etc.
 
    @OneToMany(mappedBy = "botByBotId", cascade = CascadeType.ALL)
    public Collection<UpdateEntity> getUpdatesById() {
        return updatesById;
    }
 
    public void setUpdatesById(Collection<UpdateEntity> updatesById) {
        this.updatesById = updatesById;
    }
}
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
import javax.persistence.*;
import java.util.Collection;
import java.util.Objects;
 
@Entity
@Table(name = "updates", schema = "mydb", catalog = "")
@IdClass(UpdateEntityPK.class)
public class UpdateEntity {
 
    private int id;
    private int updateId;
    private int updateDate;
    private int botId;
    private BotEntity botByBotId;
 
// Constructors
 
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    @Column(name = "id")
    public int getId() {
        return id;
    }
 
    public void setId(int id) {
        this.id = id;
    }
 
    @Id
    @Column(name = "bot_id")
    public int getBotId() {
        return botId;
    }
 
    public void setBotId(int botId) {
        this.botId = botId;
    }
 
    // //Getters, Setters, Hashcode etc.
 
    @ManyToOne
    @JoinColumn(name = "bot_id", referencedColumnName = "id", nullable = false, insertable = false, updatable = false)
    public BotEntity getBotByBotId() {
        return botByBotId;
    }
 
    public void setBotByBotId(BotEntity botByBotId) {
        this.botByBotId = botByBotId;
        this.botId = botByBotId.getId();
    }
}

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 javax.persistence.*;
import java.io.Serializable;
import java.util.Objects;
 
public class UpdateEntityPK implements Serializable {
    private int id;
    private int botId;
 
    @Column(name = "id")
    @Id
    public int getId() {
        return id;
    }
 
    public void setId(int id) {
        this.id = id;
    }
 
    @Column(name = "bot_id")
    @Id
    public int getBotId() {
        return botId;
    }
 
    public void setBotId(int botId) {
        this.botId = botId;
    }
 
    @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;
        UpdateEntityPK that = (UpdateEntityPK) o;
        return id == that.id &&
                botId == that.botId;
    }
 
    @Override
    public int hashCode() {
 
        return Objects.hash(id, botId);
    }
}
Код, на котором ловлю эксепшен:

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
session = HibernateUtil.getSessionFactory().openSession();
            transaction = session.getTransaction();
            transaction.begin();
 
            CriteriaBuilder builder = session.getCriteriaBuilder();
            CriteriaQuery<BotEntity> query = builder.createQuery(BotEntity.class);
            Root<BotEntity> root = query.from(BotEntity.class);
            query.select(root);
 
            Query<BotEntity> q = session.createQuery(query);
 
            List<BotEntity> botList = q.getResultList();
 
            for (BotEntity botEntity : botList) {
 
                List<UpdateEntity> updateEntityList = new ArrayList<>();
 
                for (Update u : updates) {
 
                    UpdateEntity updateEntity = new UpdateEntity(u, botEntity);
                    updateEntityList.add(updateEntity);
                }
 
                botEntity.setUpdatesById(updateEntityList);
                session.saveOrUpdate(botEntity);
 
            }
 
            transaction.commit();
Эксепшен на коммите:

"Error during managed flush [A different object with the same identifier value was already associated with the session : [com.dev.model.UpdateEntity#com.dev.model .UpdateEntityPK@3c4]"
"javax.persistence.EntityExistsException : A different object with the same identifier value was already associated with the session : [com.dev.model.UpdateEntity#com.dev.model .UpdateEntityPK@3c4]"

Заранее благодарен за любые идеи!
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
07.02.2018, 15:09
Ответы с готовыми решениями:

mde файл. Halp!!!
Имею базу разбитую на две части, в одной данные, в другой всё остальое. Захотел наконец mde файлик создать. В части данными проблем нет, а...

Java8
Ребята, привет. Помогите пожалуйста, полный ноль в восьмой джаве. Надо переписать кусок-кровь-из-глаз-кода с помощью всяких опшнлов, мапов...

Java8 groupingBy
Допустим есть мапа Map&lt;String, String&gt; field1_ru_RU -&gt; &quot;field1_value_for_ru_RU&quot; field1_en_US -&gt; &quot;field1_value_for_en_US&quot; field2_ru_RU...

2
Эксперт Java
3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220
07.02.2018, 18:56
есть идея почитать доки на тему
Цитата Сообщение от protokot Посмотреть сообщение
IdClass(UpdateEntityPK.class)
0
0 / 0 / 2
Регистрация: 03.05.2017
Сообщений: 6
08.02.2018, 15:25  [ТС]
спасибо! это помогло все же конечно лучше сперва читать мануалы подробно, но всегда нет на это времени.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
08.02.2018, 15:25
Помогаю со студенческими работами здесь

ManyToOne
class Post(models.Model): author = models.ForeignKey(Profile) как сделать то же самое, но только определив отношение в модели...

ManyToOne in Hibernate
Здравствуйте. Помогите решить проблему... Я питаюсь реализовать связь в своем проект &quot;ManytoOne&quot;. Коротко опишу функционал: есть...

Android studio и java8 (гугл не помог)
Вобщем, никак не хочет определять java, путь в ручную указывал, переменную среды создавал(по совету гугла) всё равно не видит. Что делать и...

ManyToOne Hibernate Annotation
В общем, нужно создать отношение ManyToOne класса Car к классу Brand Вот класс Car @Entity @SequenceGenerator(name =...

OneToMany ManyToOne проблемы
Добрый день, начал разбираться с onetomany и manytoone, и возникли проблемы и вопросы. @Entity @Table(name = &quot;user&quot;) ...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и источниками (напряжения, ЭДС и тока). Найти токи и напряжения во всех элементах. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru