- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在下面提供的代码中,当我运行 HibernateDAOImplTest 时,重复项被插入到项表中。我正在保存两个客户和项目,有两个项目(肥皂,洋葱)在客户(RAJ 和 DESH)之间很常见,我只想在项目表中插入这两个项目一次(不需要重复)但是我需要 customer_item_mapping 表中的客户-项目映射。
我在用
org.hibernate.annotations.Cascade;
org.hibernate.annotations.CascadeType;
==========表格===========
CREATE TABLE customer_item_mapping ( mapping_id int(11) unsigned NOT NULL AUTO_INCREMENT, item_id int(100) NOT NULL, customer_id int(11) NOT NULL, PRIMARY KEY (mapping_id))
CREATE TABLE customer ( customer_id int(11) unsigned NOT NULL AUTO_INCREMENT, name varchar(100) NOT NULL, PRIMARY KEY (customer_id) )
CREATE TABLE item ( item_id int(11) unsigned NOT NULL AUTO_INCREMENT, name varchar(100) NOT NULL, PRIMARY KEY (item_id) )
==========第一个实体===========
@Entity @Cacheable
@Table(name = "customer_item_mapping")
@DynamicInsert(value=true)
@DynamicUpdate(value=true)
@Cache(usage = CacheConcurrencyStrategy.READ_WRITE)
public class CustomerItemMapping implements Serializable {
private static final long serialVersionUID = 3500101963230957017L;
@Id
@GeneratedValue(strategy = IDENTITY)
@Column(name = "mapping_id", unique = true, nullable = false)
private Integer mappingId;
@ManyToOne(fetch = FetchType.EAGER)
@JoinColumn(name = "item_id", nullable = false)
private Item item;
@Column(name = "customer_id", nullable = false)
private Integer customerId;
}
==========第二实体===========
@Entity @Cacheable
@Table(name = "customer")
@DynamicInsert(value=true)
@DynamicUpdate(value=true)
@Cache(usage = CacheConcurrencyStrategy.READ_WRITE)
public class Customer implements Serializable{
private static final long serialVersionUID = 3886876059389214345L;
@Id
@GeneratedValue(strategy = IDENTITY)
@Column(name = "customer_id", unique = true, nullable = false)
private Integer customerId;
@JoinColumn(name = "name", nullable = false)
private String customerName;
@OneToMany(fetch = FetchType.EAGER)
@JoinTable(name = "customer_item_mapping", joinColumns = @JoinColumn(name = "customer_id"), inverseJoinColumns = @JoinColumn(name = "item_id"))
@Cascade({CascadeType.ALL})
private Set<Item> itemSet;
}
==========第三实体===========
@Entity @Cacheable
@Table(name = "item")
@DynamicInsert(value=true)
@DynamicUpdate(value=true)
@Cache(usage = CacheConcurrencyStrategy.READ_WRITE)
public class Item implements Serializable{
private static final long serialVersionUID = 3886876059389214345L;
@Id
@GeneratedValue(strategy = IDENTITY)
@Column(name = "item_id", unique = true, nullable = false)
private Integer itemId;
@JoinColumn(name = "name", nullable = false)
private String name;
public Item(String name){
this.name=name;
}
}
==========HibernateDAOImpl===========
package com.myapp.txn.impl.genric.dao;
import org.hibernate.Session;
import com.myapp.txn.exception.PersistenceException;
import com.myapp.txn.genric.dao.HibernateDAO;
public class HibernateDAOImpl {
public Integer saveEntity(String entityType, Object obj, Session session) throws PersistenceException{
Integer id=0;
try {
id = (Integer) session.save(entityType, obj);
}catch (Exception e) {
throw new PersistenceException(e);
}
return id;
}
}
==========HibernateDAOImplTest===========
package com.myapp.txn.impl.genric.dao;
public class HibernateDAOImplTest {
@Autowired
private HibernateDAOImpl hibernateDAOImpl;
@Test
public void saveEntityTest(){
Set<Item> itemSet=new HashSet<Item>();
Item item=new Item("Onion");
itemSet.add(item);
item=new Item("Soap");
itemSet.add(item);
item=new Item("Paneer");
itemSet.add(item);
Customer customer=new Customer();
customer.setName("RAJ");
customer.setItemSet(itemSet);
hibernateDAOImpl.saveEntity(customer);
itemSet=new HashSet<Item>();
Item item=new Item("Onion");
itemSet.add(item);
item=new Item("Soap");
itemSet.add(item);
item=new Item("Daaru");
itemSet.add(item);
customer=new Customer();
customer.setName("DESH");
customer.setItemSet(itemSet);
hibernateDAOImpl.saveEntity(customer);
}
}
最佳答案
您需要使用@ManyToMany 映射。 @ManyToOne 或 @OneToMAny 不适用于您的情况。
关于java - 如何防止@Cascade({CascadeType.ALL}) 保存重复的重复记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31241507/
当我在注册表上编辑 UID 时,客户表上的 parentid 列应该会更改。它不是那样做的。有什么建议吗? 客户 CREATE TABLE `clients` ( `id` INT(255)
假设我有两个下表: CREATE TABLE post ( id bigint(20) NOT NULL AUTO_INCREMENT, text text , PRIMAR
假设我有两个下表: CREATE TABLE post ( id bigint(20) NOT NULL AUTO_INCREMENT, text text , PRIMAR
TypeORM 中的级联选项是重叠的还是有完全不同的目的?他们在文档中的描述非常稀少,部分缺失,或者我找不到。 IOW,请执行以下选项 { cascade: "update" } = { onUpda
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 2 年前。 Improve
我正在使用 SpringBoot + PostgreSQL + JPA Hibernate,一切似乎都工作正常,但是 Cascade.ALL 属性未应用于表 user_roles。我错过了什么重要的事
我在使用 Doctrine 2 的实体之间的级联关系时遇到了问题。 我有一个与父事件相关的 Media 实体: class Media { /** * @ORM\OneToOne(t
以下是我的示例代码的一部分: public static void main(String[] args) throws Exception { // TODO code applicatio
至少在过去的 6 个小时里我一直在不停地愚弄这个问题,但我就是不明白问题是什么。我在 SpringBoot 项目中设置了两个类(User 和 Item),这两个类之间具有双向关系,如下所示: @One
我已经尝试了我在网上找到的一切,但没有任何东西能让这个或类似的程序在我的电脑上运行。我已经尝试将绝对路径 (C:\opencv\sources\data\haarcascades\haarcascad
我开始安装 vagrant-cascading-hadoop-cluster github项目,但是出现了一些错误,无法结束安装。 当我做“vagrant up”时 sina@linux:/media
我有一个定义如下所示的表关系,我正在尝试从 Entity2(Table2) 级联持久性和删除意味着从 table2 中删除记录应该删除 table3 中的条目并在 table2 中保存数据并将相关数据
我无法在 DELETE CASCADE ON UPDATE CASCADE 上添加外键约束。 我使用两个简单的表格。 TAB1 有 2 列:ID int(10) unsigned NOT NULL A
我的烫金作业被翻译成 9 个 MapReduce 作业(m/r 作业)。对我来说理解每个 m/r 作业代表代码的哪一部分并不容易。有什么可以帮助我更好地了解我的工作吗? //这是从 Tapad 的内部
Cascading Cascading 是 MapReduce 的替代 API,它实际上使用 MapReduce,但允许您以简化的方式编写 MapReduce 代码。 以下示例显示了 Cascad
我有一个关于 Hibernate 的一般性问题,我正在与之抗争。 我有 A 类和 B 类,其中 B 依赖于 A 在我的代码中,当我调用 em.persist(objOfTypeA) 时,我希望插入会插
我有以下实体: @Entity @Table(name = "BOOKS") public class Book { @Id @GeneratedValue(generator = "SE
我正在使用基于 JQuery Cascade plugin ;也许它可以工作,但我发现它有很多问题。 也许有人已经遇到过这个插件,也许可以提供帮助。 所以,我使用这个插件进行位置过滤 http://c
表 DISPLAY_TAB 下面是一个可以包含父选项卡和子选项卡的自引用表。一个父标签可以有多个子标签,一个子标签可以属于多个父标签。 我想在主表和关系表之间建立一个CASCADE DELETE关系
我有一个表 B,它有表 A 的外键,现在我想在 A 上做一些“删除级联”的事情,但 PostgreSQL 不接受以下内容: DELETE FROM ATable WHERE aid IN (
我是一名优秀的程序员,十分优秀!