В моем приложении (сервере) я создаю сеанс Hibernate в начале обработки запроса, используя "sessionFactory.openSession()". Я извлекаю объект, вношу в него некоторые изменения в каком-то другом классе, а затем выполняю saveOrUpdate следующим образом:
Session session = sessionFactory.getCurrentSession();
Transaction dbTransaction = session.getTransaction();
dbTransaction.begin();
session.saveOrUpdate(entity);
dbTransaction.commit()
Я также установил указанное ниже свойство в файле конфигурации.
thread
Однако, когда я выполняю session.saveOrUpdate(entity), я получаю следующее исключение. Я думаю, что причина приведенного ниже исключения: "getCurrentSession()" не получает сеанс, который я открыл с помощью "sessionFactory.openSession()", но я не могу понять, почему он не получает текущий сеанс, который я открыл с помощью "sessionFactory.openSession()", когда на сервере начинается обработка запроса.
Трассировка стека ошибок:
org.hibernate.HibernateException: I l l e g a l a t t e m p t t o a s s o c i a t e a c o l l e c t i o n w i t h < b r / > t w o o p e n s e s s i o n s a t o r g . h i b e r n a t e . c o l l e c t i o n . i n t e r n a l . A b s t r a c t P e r s i s t e n t C o l l e c t i o n . s e t C u r r e n t S e s s i o n ( A b s t r a c t P e r s i s t e n t C o l l e c t i o n . j a v a : 6 3 8 ) < b r / > a t o r g . h i b e r n a t e . e v e n t . i n t e r n a l . O n U p d a t e V i s i t o r . p r o c e s s C o l l e c t i o n ( O n U p d a t e V i s i t o r . j a v a : 6 5 ) < b r / > a t o r g . h i b e r n a t e . e v e n t . i n t e r n a l . A b s t r a c t V i s i t o r . p r o c e s s V a l u e ( A b s t r a c t V i s i t o r . j a v a : 1 2 1 ) < b r / > a t o r g . h i b e r n a t e . e v e n t . i n t e r n a l . A b s t r a c t V i s i t o r . p r o c e s s V a l u e ( A b s t r a c t V i s i t o r . j a v a : 8 2 ) < b r / > a t o r g . h i b e r n a t e . e v e n t . i n t e r n a l . A b s t r a c t V i s i t o r . p r o c e s s E n t i t y P r o p e r t y V a l u e s ( A b s t r a c t V i s i t o r . j a v a : 7 6 ) < b r / > a t o r g . h i b e r n a t e . e v e n t . i n t e r n a l . A b s t r a c t V i s i t o r . p r o c e s s ( A b s t r a c t V i s i t o r . j a v a : 1 4 3 ) < b r / > a t o r g . h i b e r n a t e . e v e n t . i n t e r n a l . D e f a u l t S a v e O r U p d a t e E v e n t L i s t e n e r . p e r f o r m U p d a t e ( D e f a u l t S a v e O r U p d a t e E v e n t L i s t e n e r . j a v a : 3 0 5 ) < b r / > a t o r g . h i b e r n a t e . e v e n t . i n t e r n a l . D e f a u l t S a v e O r U p d a t e E v e n t L i s t e n e r . e n t i t y I s D e t a c h e d ( D e f a u l t S a v e O r U p d a t e E v e n t L i s t e n e r . j a v a : 2 4 1 ) < b r / > a t o r g . h i b e r n a t e . e v e n t . i n t e r n a l . D e f a u l t S a v e O r U p d a t e E v e n t L i s t e n e r . p e r f o rmSaveOrUpdate(DefaultSaveOrUpdateEventListener.java:109)
at org.hibernate.event.internal.DefaultSaveOrUpdateEventListener.onSaveOrUpdate(DefaultSaveOrUpdateEventListener.java:90)
at org.hibernate.internal.SessionImpl.fireSaveOrUpdate(SessionImpl.java:735)
at org.hibernate.internal.SessionImpl.saveOrUpdate(SessionImpl.java:727)
at org.hibernate.internal.SessionImpl.saveOrUpdate(SessionImpl.java:723)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:601)
at org.hibernate.context.internal.ThreadLocalSessionContext$TransactionProtectionWrapper.invoke(ThreadLocalSessionContext.java:352)
at com.sun.proxy.$Proxy24.saveOrUpdate(Unknown Source)
at org.app.purchase.utils.PurchaseUtils.saveOrUpdateTransactionNew(PurchaseUtils.java:46)
at org.app.purchase.model.Transaction.createRefundTransaction(Transaction.java:422)
at org.app.purchase.application.RefundTransaction.refundTransaction(RefundTransaction.java:64)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:601)
at org.restlet.resource.ServerResource.doHandle(ServerResource.java:449)
at org.restlet.resource.ServerResource.get(ServerResource.java:645)
at org.restlet.resource.ServerResource.doHandle(ServerResource.java:527)
at org.restlet.resource.ServerResource.doNegotiatedHandle(ServerResource.java:587)
at org.restlet.resource.ServerResource.doConditionalHandle(ServerResource.java:299)
at org.restlet.resource.ServerResource.handle(ServerResource.java:846)
at org.restlet.resource.Finder.handle(Finder.java:510)
at org.restlet.routing.Filter.doHandle(Filter.java:156)
at org.restlet.routing.Filter.handle(Filter.java:203)
at org.restlet.routing.Router.doHandle(Router.java:497)
at org.restlet.routing.Router.handle(Router.java:737)
at org.restlet.routing.Filter.doHandle(Filter.java:156)
at org.restlet.routing.Filter.handle(Filter.java:203)
at org.restlet.routing.Filter.doHandle(Filter.java:156)
at org.restlet.routing.Filter.handle(Filter.java:203)
at org.restlet.routing.Filter.doHandle(Filter.java:156)
at org.restlet.engine.application.StatusFilter.doHandle(StatusFilter.java:151)
at org.restlet.routing.Filter.handle(Filter.java:203)
at org.restlet.routing.Filter.doHandle(Filter.java:156)
at org.restlet.routing.Filter.handle(Filter.java:203)
at org.restlet.engine.ChainHelper.handle(ChainHelper.java:111)
at org.restlet.engine.application.ApplicationHelper.handle(ApplicationHelper.java:72)
at org.restlet.Application.handle(Application.java:388)
at org.restlet.routing.Filter.doHandle(Filter.java:156)
at org.restlet.routing.Filter.handle(Filter.java:203)
at org.restlet.routing.Router.doHandle(Router.java:497)
at org.restlet.routing.Router.handle(Router.java:737)
at org.restlet.routing.Filter.doHandle(Filter.java:156)
at org.restlet.routing.Filter.handle(Filter.java:203)
at org.restlet.routing.Router.doHandle(Router.java:497)
at org.restlet.routing.Router.handle(Router.java:737)
at org.restlet.routing.Filter.doHandle(Filter.java:156)
at org.restlet.engine.application.StatusFilter.doHandle(StatusFilter.java:151)
at org.restlet.routing.Filter.handle(Filter.java:203)
at org.restlet.routing.Filter.doHandle(Filter.java:156)
at org.restlet.routing.Filter.handle(Filter.java:203)
at org.restlet.engine.ChainHelper.handle(ChainHelper.java:111)
at org.restlet.Component.handle(Component.java:388)
at org.restlet.Server.handle(Server.java:488)
at org.restlet.engine.http.connector.BaseServerHelper.handle(BaseServerHelper.java:158)
at org.restlet.engine.http.connector.BaseServerHelper.handleInbound(BaseServerHelper.java:167)
at org.restlet.engine.http.connector.BaseHelper.handleNextInbound(BaseHelper.java:418)
at org.restlet.engine.http.connector.Connection.readMessages(Connection.java:695)
at org.restlet.engine.http.connector.Controller$2.run(Controller.java:95)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
at java.lang.Thread.run(Thread.java:722)
Подробнее здесь: https://stackoverflow.com/questions/196 ... ection-wit
«org.hibernate.HibernateException: незаконная попытка связать коллекцию с двумя открытыми сеансами», даже если контекст ⇐ JAVA
Программисты JAVA общаются здесь
1721926860
Anonymous
В моем приложении (сервере) я создаю сеанс Hibernate в начале обработки запроса, используя "sessionFactory.openSession()". Я извлекаю объект, вношу в него некоторые изменения в каком-то другом классе, а затем выполняю saveOrUpdate следующим образом:
Session session = sessionFactory.getCurrentSession();
Transaction dbTransaction = session.getTransaction();
dbTransaction.begin();
session.saveOrUpdate(entity);
dbTransaction.commit()
Я также установил указанное ниже свойство в файле конфигурации.
thread
Однако, когда я выполняю session.saveOrUpdate(entity), я получаю следующее исключение. Я думаю, что причина приведенного ниже исключения: "getCurrentSession()" не получает сеанс, который я открыл с помощью "sessionFactory.openSession()", но я не могу понять, почему он не получает текущий сеанс, который я открыл с помощью "sessionFactory.openSession()", когда на сервере начинается обработка запроса.
[b]Трассировка стека ошибок:[/b]
org.hibernate.HibernateException: I l l e g a l a t t e m p t t o a s s o c i a t e a c o l l e c t i o n w i t h < b r / > t w o o p e n s e s s i o n s a t o r g . h i b e r n a t e . c o l l e c t i o n . i n t e r n a l . A b s t r a c t P e r s i s t e n t C o l l e c t i o n . s e t C u r r e n t S e s s i o n ( A b s t r a c t P e r s i s t e n t C o l l e c t i o n . j a v a : 6 3 8 ) < b r / > a t o r g . h i b e r n a t e . e v e n t . i n t e r n a l . O n U p d a t e V i s i t o r . p r o c e s s C o l l e c t i o n ( O n U p d a t e V i s i t o r . j a v a : 6 5 ) < b r / > a t o r g . h i b e r n a t e . e v e n t . i n t e r n a l . A b s t r a c t V i s i t o r . p r o c e s s V a l u e ( A b s t r a c t V i s i t o r . j a v a : 1 2 1 ) < b r / > a t o r g . h i b e r n a t e . e v e n t . i n t e r n a l . A b s t r a c t V i s i t o r . p r o c e s s V a l u e ( A b s t r a c t V i s i t o r . j a v a : 8 2 ) < b r / > a t o r g . h i b e r n a t e . e v e n t . i n t e r n a l . A b s t r a c t V i s i t o r . p r o c e s s E n t i t y P r o p e r t y V a l u e s ( A b s t r a c t V i s i t o r . j a v a : 7 6 ) < b r / > a t o r g . h i b e r n a t e . e v e n t . i n t e r n a l . A b s t r a c t V i s i t o r . p r o c e s s ( A b s t r a c t V i s i t o r . j a v a : 1 4 3 ) < b r / > a t o r g . h i b e r n a t e . e v e n t . i n t e r n a l . D e f a u l t S a v e O r U p d a t e E v e n t L i s t e n e r . p e r f o r m U p d a t e ( D e f a u l t S a v e O r U p d a t e E v e n t L i s t e n e r . j a v a : 3 0 5 ) < b r / > a t o r g . h i b e r n a t e . e v e n t . i n t e r n a l . D e f a u l t S a v e O r U p d a t e E v e n t L i s t e n e r . e n t i t y I s D e t a c h e d ( D e f a u l t S a v e O r U p d a t e E v e n t L i s t e n e r . j a v a : 2 4 1 ) < b r / > a t o r g . h i b e r n a t e . e v e n t . i n t e r n a l . D e f a u l t S a v e O r U p d a t e E v e n t L i s t e n e r . p e r f o rmSaveOrUpdate(DefaultSaveOrUpdateEventListener.java:109)
at org.hibernate.event.internal.DefaultSaveOrUpdateEventListener.onSaveOrUpdate(DefaultSaveOrUpdateEventListener.java:90)
at org.hibernate.internal.SessionImpl.fireSaveOrUpdate(SessionImpl.java:735)
at org.hibernate.internal.SessionImpl.saveOrUpdate(SessionImpl.java:727)
at org.hibernate.internal.SessionImpl.saveOrUpdate(SessionImpl.java:723)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:601)
at org.hibernate.context.internal.ThreadLocalSessionContext$TransactionProtectionWrapper.invoke(ThreadLocalSessionContext.java:352)
at com.sun.proxy.$Proxy24.saveOrUpdate(Unknown Source)
at org.app.purchase.utils.PurchaseUtils.saveOrUpdateTransactionNew(PurchaseUtils.java:46)
at org.app.purchase.model.Transaction.createRefundTransaction(Transaction.java:422)
at org.app.purchase.application.RefundTransaction.refundTransaction(RefundTransaction.java:64)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:601)
at org.restlet.resource.ServerResource.doHandle(ServerResource.java:449)
at org.restlet.resource.ServerResource.get(ServerResource.java:645)
at org.restlet.resource.ServerResource.doHandle(ServerResource.java:527)
at org.restlet.resource.ServerResource.doNegotiatedHandle(ServerResource.java:587)
at org.restlet.resource.ServerResource.doConditionalHandle(ServerResource.java:299)
at org.restlet.resource.ServerResource.handle(ServerResource.java:846)
at org.restlet.resource.Finder.handle(Finder.java:510)
at org.restlet.routing.Filter.doHandle(Filter.java:156)
at org.restlet.routing.Filter.handle(Filter.java:203)
at org.restlet.routing.Router.doHandle(Router.java:497)
at org.restlet.routing.Router.handle(Router.java:737)
at org.restlet.routing.Filter.doHandle(Filter.java:156)
at org.restlet.routing.Filter.handle(Filter.java:203)
at org.restlet.routing.Filter.doHandle(Filter.java:156)
at org.restlet.routing.Filter.handle(Filter.java:203)
at org.restlet.routing.Filter.doHandle(Filter.java:156)
at org.restlet.engine.application.StatusFilter.doHandle(StatusFilter.java:151)
at org.restlet.routing.Filter.handle(Filter.java:203)
at org.restlet.routing.Filter.doHandle(Filter.java:156)
at org.restlet.routing.Filter.handle(Filter.java:203)
at org.restlet.engine.ChainHelper.handle(ChainHelper.java:111)
at org.restlet.engine.application.ApplicationHelper.handle(ApplicationHelper.java:72)
at org.restlet.Application.handle(Application.java:388)
at org.restlet.routing.Filter.doHandle(Filter.java:156)
at org.restlet.routing.Filter.handle(Filter.java:203)
at org.restlet.routing.Router.doHandle(Router.java:497)
at org.restlet.routing.Router.handle(Router.java:737)
at org.restlet.routing.Filter.doHandle(Filter.java:156)
at org.restlet.routing.Filter.handle(Filter.java:203)
at org.restlet.routing.Router.doHandle(Router.java:497)
at org.restlet.routing.Router.handle(Router.java:737)
at org.restlet.routing.Filter.doHandle(Filter.java:156)
at org.restlet.engine.application.StatusFilter.doHandle(StatusFilter.java:151)
at org.restlet.routing.Filter.handle(Filter.java:203)
at org.restlet.routing.Filter.doHandle(Filter.java:156)
at org.restlet.routing.Filter.handle(Filter.java:203)
at org.restlet.engine.ChainHelper.handle(ChainHelper.java:111)
at org.restlet.Component.handle(Component.java:388)
at org.restlet.Server.handle(Server.java:488)
at org.restlet.engine.http.connector.BaseServerHelper.handle(BaseServerHelper.java:158)
at org.restlet.engine.http.connector.BaseServerHelper.handleInbound(BaseServerHelper.java:167)
at org.restlet.engine.http.connector.BaseHelper.handleNextInbound(BaseHelper.java:418)
at org.restlet.engine.http.connector.Connection.readMessages(Connection.java:695)
at org.restlet.engine.http.connector.Controller$2.run(Controller.java:95)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
at java.lang.Thread.run(Thread.java:722)
Подробнее здесь: [url]https://stackoverflow.com/questions/19615847/org-hibernate-hibernateexception-illegal-attempt-to-associate-a-collection-wit[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия