我正在尝试存储用户发出的订单的集合。一个用户可能有多个订单,但一个订单只有一个用户。这样就形成了1-M关系。Items 和 ItemOrders 之间也存在相同的关系,ItemOrder 由一个 Item 和一定数量的要订购的 Items 组成。因此,一个 ItemOrder 有一个 Item,但一个 Item 可以有多个 ItemOrder。
在我的测试套件中,我成功地正确创建了 Items 和 ItemOrders。但是,当我扩展测试以创建用户和订单时,我收到“订单”的 SQLSyntaxErrorException...这很奇怪,因为它应该是实现这两种结果的完全相同的过程...而且我不知道是什么我在这里做错了,有什么想法吗?
@Entity
public class ItemEntity implements EntityInt {
@Id
@GeneratedValue(generator = "incrementor")
@Column(name = "item_id", unique = true)
public int id;
@OneToMany(mappedBy="item")
public Set<OrderItemEntity> orderItems = new HashSet<>();
}
@Entity
public class OrderItemEntity implements EntityInt {
@Id
@GeneratedValue(generator = "incrementor")
@Column(name = "order_item_id", unique = true)
public int id;
@Column(name = "amount", nullable = false)
public int amount;
@ManyToOne
@JoinColumn(name="item_id", nullable = false)
private ItemEntity item;
public OrderItemEntity(ItemEntity item, int amount) {
this.setItem(item);
this.amount = amount;
}
public void setItem(ItemEntity item) {
if (this.item != null)
this.item.orderItems.remove(this);
this.item = item;
this.item.orderItems.add(this);
}
}
@Entity
public class OrderEntity implements EntityInt {
@Id
@GeneratedValue(generator = "incrementor")
@Column(name = "order_id", unique = true)
public int id;
@ManyToOne
@JoinColumn(name="user_id", nullable = false)
public UserEntity user;
public UserEntity getUser() {
return user;
}
public void setUser(UserEntity user) {
if (this.user != null)
this.user.orders.remove(this);
this.user = user;
this.user.orders.add(this);
}
}
EntityInt 包含主要由 BasicDao 用于执行 CRUD 操作的方法。它有 getId()、getVersion()、createVerifyIsUnqieuQuery() 等内容。
哈士奇WWW
相关分类