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

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

22.11.2016, 10:40. Показов 3987. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
Расскажи мне о Мире, бродяга
kumehtar 12.11.2025
— Расскажи мне о Мире, бродяга, Ты же видел моря и метели. Как сменялись короны и стяги, Как эпохи стрелою летели. - Этот мир — это крылья и горы, Снег и пламя, любовь и тревоги, И бескрайние. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru