|
39 / 28 / 8
Регистрация: 14.04.2012
Сообщений: 249
|
|||||||||||
Удаление Entity из БД22.11.2016, 10:40. Показов 4087. Ответов 7
Имеется класс User
Кликните здесь для просмотра всего текста
При удалении методом Кликните здесь для просмотра всего текста
возникает ошибка, что ограниечение внешнего ключа, имеется ссылка (Usera) на таблицу user_roles (таблица создаётся по полю private Set<Role> roles) Как удалить Usera и все его дочерние таблицы? Может нужно дополниельные анатации прописать? Spring Data Jpa
0
|
|||||||||||
| 22.11.2016, 10:40 | |
|
Ответы с готовыми решениями:
7
Entity Framework. Удаление entity без удаления связей
Удаление entity из модели |
|
2399 / 2224 / 565
Регистрация: 28.12.2010
Сообщений: 8,672
|
||||||
| 22.11.2016, 11:11 | ||||||
|
kostrorod, во-первых в спринг дата нет нужны писать такое удаление как у вас. Оно там уже реализовано.
Вто-вторых хорошей практикой является "мягкое" удаление. То есть вы добавляете в юезр поле deleted(boolean) и выставляете его в true когда удаляете юзера. Соответственно везде где вы получаете юзеров вы должны фильтровать по этому флагу. Если же очень хочется удалить все и вся, вам надо указать это в вашей аннотации маппинга. Примерно так
1
|
||||||
|
39 / 28 / 8
Регистрация: 14.04.2012
Сообщений: 249
|
|||
| 22.11.2016, 11:38 [ТС] | |||
|
0
|
|||
|
2399 / 2224 / 565
Регистрация: 28.12.2010
Сообщений: 8,672
|
|
| 22.11.2016, 11:55 | |
|
0
|
|
|
39 / 28 / 8
Регистрация: 14.04.2012
Сообщений: 249
|
||||||
| 22.11.2016, 11:55 [ТС] | ||||||
|
При добавлении OneToMany
Кликните здесь для просмотра всего текста
возникает ошибка Кликните здесь для просмотра всего текста
java.lang.IllegalStateException: Failed to load ApplicationContext
at org.springframework.test.context.cache.D efaultCacheAwareContextLoaderDelegate.lo adContext(DefaultCacheAwareContextLoader Delegate.java:124) at org.springframework.test.context.support .DefaultTestContext.getApplicationContex t(DefaultTestContext.java:83) at org.springframework.test.context.support .DependencyInjectionTestExecutionListene r.injectDependencies(DependencyInjection TestExecutionListener.java:117) at org.springframework.test.context.support .DependencyInjectionTestExecutionListene r.prepareTestInstance(DependencyInjectio nTestExecutionListener.java:83) at org.springframework.test.context.TestCon textManager.prepareTestInstance(TestCont extManager.java:230) at org.springframework.test.context.junit4. SpringJUnit4ClassRunner.createTest(Sprin gJUnit4ClassRunner.java:228) at org.springframework.test.context.junit4. SpringJUnit4ClassRunner$1.runReflectiveC all(SpringJUnit4ClassRunner.java:287) at org.junit.internal.runners.model.Reflect iveCallable.run(ReflectiveCallable.java: 12) at org.springframework.test.context.junit4. SpringJUnit4ClassRunner.methodBlock(Spri ngJUnit4ClassRunner.java:289) at org.springframework.test.context.junit4. SpringJUnit4ClassRunner.runChild(SpringJ Unit4ClassRunner.java:247) at org.springframework.test.context.junit4. SpringJUnit4ClassRunner.runChild(SpringJ Unit4ClassRunner.java:94) at org.junit.runners.ParentRunner$3.run(Par entRunner.java:290) at org.junit.runners.ParentRunner$1.schedul e(ParentRunner.java:71) at org.junit.runners.ParentRunner.runChildr en(ParentRunner.java:288) at org.junit.runners.ParentRunner.access$00 0(ParentRunner.java:58) at org.junit.runners.ParentRunner$2.evaluat e(ParentRunner.java:268) at org.springframework.test.context.junit4. statements.RunBeforeTestClassCallbacks.e valuate(RunBeforeTestClassCallbacks.java :61) at org.springframework.test.context.junit4. statements.RunAfterTestClassCallbacks.ev aluate(RunAfterTestClassCallbacks.java:7 0) at org.junit.runners.ParentRunner.run(Paren tRunner.java:363) at org.springframework.test.context.junit4. SpringJUnit4ClassRunner.run(SpringJUnit4 ClassRunner.java:191) at org.junit.runner.JUnitCore.run(JUnitCore .java:137) at com.intellij.junit4.JUnit4IdeaTestRunner .startRunnerWithArgs(JUnit4IdeaTestRunne r.java:117) at com.intellij.junit4.JUnit4IdeaTestRunner .startRunnerWithArgs(JUnit4IdeaTestRunne r.java:42) at com.intellij.rt.execution.junit.JUnitSta rter.prepareStreamsAndStart(JUnitStarter .java:262) at com.intellij.rt.execution.junit.JUnitSta rter.main(JUnitStarter.java:84) at sun.reflect.NativeMethodAccessorImpl.inv oke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.inv oke(NativeMethodAccessorImpl.java:62) at sun.reflect.DelegatingMethodAccessorImpl .invoke(DelegatingMethodAccessorImpl.jav a:43) at java.lang.reflect.Method.invoke(Method.j ava:498) at com.intellij.rt.execution.application.Ap pMain.main(AppMain.java:147) Caused by: org.springframework.beans.factory.BeanCr eationException: Error creating bean with name 'emf' defined in class path resource [spring/spring-config.xml]: Invocation of init method failed; nested exception is org.hibernate.AnnotationException: Use of @OneToMany or @ManyToMany targeting an unmapped class: model.User.roles[model.Role] at org.springframework.beans.factory.suppor t.AbstractAutowireCapableBeanFactory.ini tializeBean(AbstractAutowireCapableBeanF actory.java:1578) at org.springframework.beans.factory.suppor t.AbstractAutowireCapableBeanFactory.doC reateBean(AbstractAutowireCapableBeanFac tory.java:545) at org.springframework.beans.factory.suppor t.AbstractAutowireCapableBeanFactory.cre ateBean(AbstractAutowireCapableBeanFacto ry.java:482) at org.springframework.beans.factory.suppor t.AbstractBeanFactory$1.getObject(Abstra ctBeanFactory.java:306) at org.springframework.beans.factory.suppor t.DefaultSingletonBeanRegistry.getSingle ton(DefaultSingletonBeanRegistry.java:23 0) at org.springframework.beans.factory.suppor t.AbstractBeanFactory.doGetBean(Abstract BeanFactory.java:302) at org.springframework.beans.factory.suppor t.AbstractBeanFactory.getBean(AbstractBe anFactory.java:197) at org.springframework.context.support.Abst ractApplicationContext.getBean(AbstractA pplicationContext.java:1076) at org.springframework.context.support.Abst ractApplicationContext.finishBeanFactory Initialization(AbstractApplicationContex t.java:851) at org.springframework.context.support.Abst ractApplicationContext.refresh(AbstractA pplicationContext.java:541) at org.springframework.test.context.support .AbstractGenericContextLoader.loadContex t(AbstractGenericContextLoader.java:128) at org.springframework.test.context.support .AbstractGenericContextLoader.loadContex t(AbstractGenericContextLoader.java:60) at org.springframework.test.context.support .AbstractDelegatingSmartContextLoader.de legateLoading(AbstractDelegatingSmartCon textLoader.java:108) at org.springframework.test.context.support .AbstractDelegatingSmartContextLoader.lo adContext(AbstractDelegatingSmartContext Loader.java:251) at org.springframework.test.context.cache.D efaultCacheAwareContextLoaderDelegate.lo adContextInternal(DefaultCacheAwareConte xtLoaderDelegate.java:98) at org.springframework.test.context.cache.D efaultCacheAwareContextLoaderDelegate.lo adContext(DefaultCacheAwareContextLoader Delegate.java:116) ... 29 more Caused by: org.hibernate.AnnotationException: Use of @OneToMany or @ManyToMany targeting an unmapped class: model.User.roles[model.Role] at org.hibernate.cfg.annotations.Collection Binder.bindManyToManySecondPass(Collecti onBinder.java:1223) at org.hibernate.cfg.annotations.Collection Binder.bindStarToManySecondPass(Collecti onBinder.java:800) at org.hibernate.cfg.annotations.Collection Binder$1.secondPass(CollectionBinder.jav a:725) at org.hibernate.cfg.CollectionSecondPass.d oSecondPass(CollectionSecondPass.java:54 ) at org.hibernate.boot.internal.InFlightMeta dataCollectorImpl.processSecondPasses(In FlightMetadataCollectorImpl.java:1621) at org.hibernate.boot.internal.InFlightMeta dataCollectorImpl.processSecondPasses(In FlightMetadataCollectorImpl.java:1589) at org.hibernate.boot.model.process.spi.Met adataBuildingProcess.complete(MetadataBu ildingProcess.java:278) at org.hibernate.jpa.boot.internal.EntityMa nagerFactoryBuilderImpl.metadata(EntityM anagerFactoryBuilderImpl.java:847) at org.hibernate.jpa.boot.internal.EntityMa nagerFactoryBuilderImpl.build(EntityMana gerFactoryBuilderImpl.java:874) at org.springframework.orm.jpa.vendor.Sprin gHibernateJpaPersistenceProvider.createC ontainerEntityManagerFactory(SpringHiber nateJpaPersistenceProvider.java:60) at org.springframework.orm.jpa.LocalContain erEntityManagerFactoryBean.createNativeE ntityManagerFactory(LocalContainerEntity ManagerFactoryBean.java:338) at org.springframework.orm.jpa.AbstractEnti tyManagerFactoryBean.buildNativeEntityMa nagerFactory(AbstractEntityManagerFactor yBean.java:373) at org.springframework.orm.jpa.AbstractEnti tyManagerFactoryBean.afterPropertiesSet( AbstractEntityManagerFactoryBean.java:36 2) at org.springframework.beans.factory.suppor t.AbstractAutowireCapableBeanFactory.inv okeInitMethods(AbstractAutowireCapableBe anFactory.java:1637) at org.springframework.beans.factory.suppor t.AbstractAutowireCapableBeanFactory.ini tializeBean(AbstractAutowireCapableBeanF actory.java:1574) ... 44 more
0
|
||||||
|
2399 / 2224 / 565
Регистрация: 28.12.2010
Сообщений: 8,672
|
|
| 22.11.2016, 12:00 | |
|
0
|
|
|
39 / 28 / 8
Регистрация: 14.04.2012
Сообщений: 249
|
|
| 22.11.2016, 12:13 [ТС] | |
|
0
|
|
|
2399 / 2224 / 565
Регистрация: 28.12.2010
Сообщений: 8,672
|
|
| 22.11.2016, 12:16 | |
|
kostrorod, у вас есть три варианта
1. Использовать soft delete 2. Сделать Role entity 3. Гуглить можно ли решить вашу проблему не создавая класс Role (таблица все равно создается полагаю) Я бы на вашем месте выбрал первый вариант.
1
|
|
| 22.11.2016, 12:16 | |
|
Помогаю со студенческими работами здесь
8
Каскадное удаление в Entity Framework Entity Framework Code First Каскадное удаление
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2.
При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
|
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут.
https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc
Первый документ красиво выглядит, но без схемы.
Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
|
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере".
Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
|
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти".
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2.
В качестве источника данных. . .
|
|
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер
Написал заготовку:
dotnet new console --aot -o UrlHandler
var items = args. Split(":");
var tag = items;
var id = items;
var executable = args;. . .
|
Отправка уведомления на почту при изменении наименования справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере изменения наименования типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной. . .
|
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений.
9TO2GP2bpX4
a42b81fb172ffc12ca589c7898261ccb/
https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/
Слева синяя линия -. . .
|
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. .
Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
|