gpt4 book ai didi

java - @ManyToMany - 数据不会保存在数据库中

转载 作者:搜寻专家 更新时间:2023-11-01 01:47:09 25 4
gpt4 key购买 nike

简化,在我的数据库中我有表:

Car (pk="id_car")

CarAddon (pk="id_car_fk,id_addon_fk",
`FK_car_addon_addon` FOREIGN KEY (`id_addon_fk`) REFERENCES `addon` (`id_addon`)
`FK_car_addon_car` FOREIGN KEY (`id_car_fk`) REFERENCES `car` (`id_car`)

Addon (pk="id_addon")

简而言之:我有车,很多车可以有很多插件(比如 ABS 等)。
一表有车,一表有逻辑联系。

总体而言,实体运行良好。当我想要持久单个对象时,我对持久数据没有任何问题。当我想要 FETCH 数据时,我没有问题,即。汽车->getAddon();

但是,当我要持久化一个集合时,什么也没有发生。没有抛出异常,数据库中没有新数据。

//DBManager is a singleton to create an EntityManager
EntityManager em = DBManager.getManager().createEntityManager();

em.getTransaction().begin();
Addon addon1 = new Addon();
addon1.setName("czesc1");
em.persist(addon1);
Addon addon2 = new Addon();
addon2.setName("czesc2");
em.persist(addon2);

car.setAddonCollection(new ArrayList<Addon>());
car.getAddonCollection().add(addon1);
car.getAddonCollection().add(addon2);
em.persist(car);
em.getTransaction().commit();

在这种情况下,addons 存储在 Addon 表中,car 存储在 Car 表中。 CarAddon 表中没有新数据,尽管对象 car 有良好的数据(调试器中有插件集合)。

当我将 em.persist(car) 更改为 em.merge(car) 时出现异常:

"SEVERE: Persistence error in /admin/AddAuction : java.lang.IllegalStateException: During synchronization a new object was found through a relationship that was not marked cascade PERSIST: model.entity.Car[ idCar=0 ]."

我的类的简单版本:

  @Entity
@Table(name = "addon")
@XmlRootElement
@NamedQueries({...})
public class Addon implements Serializable {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Basic(optional = false)
@NotNull
@Column(name = "id_addon")
private Integer idAddon;

@Size(max = 100)
@Column(name = "name")
private String name;

@JoinTable(name = "car_addon",
joinColumns = {
@JoinColumn(name = "id_addon_fk", referencedColumnName = "id_addon")},
inverseJoinColumns = {
@JoinColumn(name = "id_car_fk", referencedColumnName = "id_car")})
@ManyToMany
private List<Car> carCollection;

@XmlTransient
public List<Car> getCarCollection() {
return carCollection;
}

public void setCarCollection(List<Car> carCollection) {
this.carCollection = carCollection;
}
}



@Entity
@Table(name = "car")
@XmlRootElement
@NamedQueries({...)
public class Car implements Serializable {

@ManyToMany(mappedBy = "carCollection", fetch= FetchType.EAGER, cascade=CascadeType.ALL)
private List<Addon> addonCollection;

@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Basic(optional = false)
@NotNull
@Column(name = "id_car")
private Integer idCar;

@XmlTransient
public List<Addon> getAddonCollection() {
return addonCollection;
}

public void setAddonCollection(List<Addon> addonCollection) {
this.addonCollection = addonCollection;
}
}

我该如何解决?

ps1。我有:

cascade=CascadeType.ALL przy @ManyToMany private List<Car> carCollection

但这并没有解决我的问题。

PS2。我正在使用 Netbeans 7、EclipseLink 和 MySQL ( not Hibernate - I have problem with it )

最佳答案

我有一个理论似乎总是让人们对多对多集合感到困惑。问题是在内存中,关联是在两个地方进行的。在汽车的插件列表和插件的汽车列表中。在数据库中,没有这样的重复。

JPA 提供者解决这个问题的方法是通过 mappedBy 属性。由于您已经在汽车的插件列表上映射了这意味着该关系实际上是由插件的汽车列表控制的(我知道这很困惑)。

尝试添加以下内容:

addon1.setCarCollection(new ArrayList<Car>());
addon1.getCarCollection().add(car);

addon2.setCarCollection(new ArrayList<Car>());
addon2.getCarCollection().add(car);

在你坚持开车之前。

关于java - @ManyToMany - 数据不会保存在数据库中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6388640/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com