Форум программистов, компьютерный форум, киберфорум
Java: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.62/21: Рейтинг темы: голосов - 21, средняя оценка - 4.62
39 / 28 / 8
Регистрация: 14.04.2012
Сообщений: 249

Удаление Entity из БД

22.11.2016, 10:40. Показов 4087. Ответов 7

Студворк — интернет-сервис помощи студентам
Имеется класс User
Кликните здесь для просмотра всего текста
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
@Entity
@Table(name = "users", uniqueConstraints={@UniqueConstraint(columnNames={"name"})})
public class User extends NamedEntity {
    @Column(name = "email", nullable = false, unique = true)
    @Email
    @NotEmpty
    private String email;
 
    @Column(name = "password", nullable = false)
    @NotEmpty
    @Length(min = 5)
    private String password;
 
    @Column(name = "enabled", nullable = false)
    private boolean enabled = true;
 
    @Column(name = "registered", columnDefinition = "timestamp default now()")
    private Date registered = new Date();
 
    @Enumerated(EnumType.STRING)
    @ElementCollection(targetClass = Role.class)
    @CollectionTable(name = "user_roles", joinColumns = @JoinColumn(name = "user_id"))
    @Column(name = "role")
    private Set<Role> roles = new HashSet<Role>();
 
    @Column(name = "firstName")
    private String firstName;
 
    @Column(name = "LastName")
    private String LastName;
 
    @Column(name = "address")
    private String address;
 
    public User() {
    }

При удалении методом
Кликните здесь для просмотра всего текста
Java
1
2
3
4
  @Transactional
    @Modifying
    @Query("DELETE FROM User u WHERE u.id=:id ")
    int delete(@Param("id") int id);

возникает ошибка, что ограниечение внешнего ключа, имеется ссылка (Usera) на таблицу user_roles (таблица создаётся по полю private Set<Role> roles)

Как удалить Usera и все его дочерние таблицы? Может нужно дополниельные анатации прописать?

Spring Data Jpa
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
22.11.2016, 10:40
Ответы с готовыми решениями:

Entity Framework. Удаление entity без удаления связей
Вечер добрый. Есть модель Coder First. Каскадное удаление запрещено. Удаление произвожу так: try { ...

@OneToOne or @ManyToOne on `my entity#1` references an unknown entity `my entity#2`
Привет всем! У меня появилась такая ошибка когда я работаю с двумя базами, именно когда делаю save в другую базу сущность первой, ...

Удаление entity из модели
Здравствуйте, история такая. Игрался с core data и создал три entities в файле xcdatamodel (насколько понимаю это модель core data), а...

7
Эксперт Java
 Аватар для KEKCoGEN
2399 / 2224 / 565
Регистрация: 28.12.2010
Сообщений: 8,672
22.11.2016, 11:11
kostrorod, во-первых в спринг дата нет нужны писать такое удаление как у вас. Оно там уже реализовано.
Вто-вторых хорошей практикой является "мягкое" удаление. То есть вы добавляете в юезр поле deleted(boolean) и выставляете его в true когда удаляете юзера. Соответственно везде где вы получаете юзеров вы должны фильтровать по этому флагу.

Если же очень хочется удалить все и вся, вам надо указать это в вашей аннотации маппинга. Примерно так

Java
1
OneToMany(cascade=CascadeType.ALL, orphanRemoval=true)
1
39 / 28 / 8
Регистрация: 14.04.2012
Сообщений: 249
22.11.2016, 11:38  [ТС]
Цитата Сообщение от KEKCoGEN Посмотреть сообщение
в спринг дата нет нужны писать такое удаление как у вас. Оно там уже реализовано
Там реализовано void delete, а мне нужно узнать прошло ли корректно удаление.
Цитата Сообщение от KEKCoGEN Посмотреть сообщение
хорошей практикой является "мягкое" удаление
Получается, что юзер не удаляется из БД, а просто скрывается?
0
Эксперт Java
 Аватар для KEKCoGEN
2399 / 2224 / 565
Регистрация: 28.12.2010
Сообщений: 8,672
22.11.2016, 11:55
Цитата Сообщение от kostrorod Посмотреть сообщение
ам реализовано void delete, а мне нужно узнать прошло ли корректно удаление.
если удаление не произойдет, вылетит исключение.

Цитата Сообщение от kostrorod Посмотреть сообщение
Получается, что юзер не удаляется из БД, а просто скрывается?
да
0
39 / 28 / 8
Регистрация: 14.04.2012
Сообщений: 249
22.11.2016, 11:55  [ТС]
При добавлении OneToMany
Кликните здесь для просмотра всего текста
Java
1
2
3
4
5
6
 @Enumerated(EnumType.STRING)
    @ElementCollection(targetClass = Role.class)
    @CollectionTable(name = "user_roles", joinColumns = @JoinColumn(name = "user_id"))
    @OneToMany(cascade=CascadeType.ALL, orphanRemoval=true)
    @Column(name = "role")
    private Set<Role> roles = new HashSet<Role>();

возникает ошибка
Кликните здесь для просмотра всего текста
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
Эксперт Java
 Аватар для KEKCoGEN
2399 / 2224 / 565
Регистрация: 28.12.2010
Сообщений: 8,672
22.11.2016, 12:00
Цитата Сообщение от kostrorod Посмотреть сообщение
Use of @OneToMany or @ManyToMany targeting an unmapped class: model.User.roles[model.Role]
this
0
39 / 28 / 8
Регистрация: 14.04.2012
Сообщений: 249
22.11.2016, 12:13  [ТС]
Цитата Сообщение от KEKCoGEN Посмотреть сообщение
this
это enum
0
Эксперт Java
 Аватар для KEKCoGEN
2399 / 2224 / 565
Регистрация: 28.12.2010
Сообщений: 8,672
22.11.2016, 12:16
kostrorod, у вас есть три варианта
1. Использовать soft delete
2. Сделать Role entity
3. Гуглить можно ли решить вашу проблему не создавая класс Role (таблица все равно создается полагаю)

Я бы на вашем месте выбрал первый вариант.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
22.11.2016, 12:16
Помогаю со студенческими работами здесь

Каскадное удаление в Entity Framework
Сегодня наткнулся на такую беду: entity framework каскадно удаляет только те сущности, которые уже были загружены заранее. Можно ли как-то...

Entity Framework Code First Каскадное удаление
Создал базу данных с помощью Entity Framework Code First: namespace Portal.Models { public class Photo { ...

Entity Framework - Рекурсивное удаление подзадач
Есть такая вот модель public class TaskModel { public int Id { get; set; } public string Title { get; set; } public...

Entity Framework удаление связанных записей (Ирархия)
Привет, есть модель данных. public class Tree { public Tree Parent { get; set; } public...

Entity Framework, как правильно убрать каскадное удаление в моем случае?
public class Task : BaseIntity { public string Name { get; set; } ...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Автозаполнение реквизита при выборе элемента справочника
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, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru