为了账号安全,请及时绑定邮箱和手机立即绑定

无法为第二种情况映射 OneToMany 和 ManyToOne?

无法为第二种情况映射 OneToMany 和 ManyToOne?

幕布斯6054654 2023-09-20 15:53:42
我正在尝试存储用户发出的订单的集合。一个用户可能有多个订单,但一个订单只有一个用户。这样就形成了1-M关系。Items 和 ItemOrders 之间也存在相同的关系,ItemOrder 由一个 Item 和一定数量的要订购的 Items 组成。因此,一个 ItemOrder 有一个 Item,但一个 Item 可以有多个 ItemOrder。在我的测试套件中,我成功地正确创建了 Items 和 ItemOrders。但是,当我扩展测试以创建用户和订单时,我收到“订单”的 SQLSyntaxErrorException...这很奇怪,因为它应该是实现这两种结果的完全相同的过程...而且我不知道是什么我在这里做错了,有什么想法吗?@Entitypublic 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<>();}@Entitypublic 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);    }}@Entitypublic 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() 等内容。
查看完整描述

1 回答

?
哈士奇WWW

TA贡献1799条经验 获得超6个赞

“您的 SQL 语法有错误;请检查与您的 MySQL 服务器版本对应的手册以获取正确的语法错误” Hibernate 4

问题是我将我的表命名为“订单”。这是从上面的堆栈跟踪中获得的。


查看完整回答
反对 回复 2023-09-20
  • 1 回答
  • 0 关注
  • 75 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信