java - 使用 Spring Boot 的 Hibernate 上的表列映射错误

标签 java mysql spring hibernate spring-boot

我在 MySql 数据库上有两个表。 Item、ItemGroup 与 Item.groupid -> ItemGroup.id 相关 我还使用 hibernate-entitymanager 和 spring boot。这是我的 Item 和 ItemGroup 实体类。

项目.java

package com.thiha.entities;

import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;

@Entity
public class Item {
    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    private Integer id;
    private String createdDate;
    private String modifiedDate;
    private String itemCode;
    private String description;
    private int groupId;
    private double quantity;
    private double price;
    private int recordStatus;
    private ItemGroup itemGroup;

    @ManyToOne
    @JoinColumn(name = "groupid")
    public ItemGroup getItemGroup() {
        return itemGroup;
    }

    public Integer getId() {
        return id;
    }
    public void setId(Integer id) {
        this.id = id;
    }
    public String getCreatedDate() {
        return createdDate;
    }
    public void setCreatedDate(String createdDate) {
        this.createdDate = createdDate;
    }
    public String getModifiedDate() {
        return modifiedDate;
    }
    public void setModifiedDate(String modifiedDate) {
        this.modifiedDate = modifiedDate;
    }
    public String getItemCode() {
        return itemCode;
    }
    public void setItemCode(String itemCode) {
        this.itemCode = itemCode;
    }
    public String getDescription() {
        return description;
    }
    public void setDescription(String description) {
        this.description = description;
    }
    public int getGroupId() {
        return groupId;
    }
    public void setGroupId(int groupId) {
        this.groupId = groupId;
    }
    public double getQuantity() {
        return quantity;
    }
    public void setQuantity(double quantity) {
        this.quantity = quantity;
    }
    public double getPrice() {
        return price;
    }
    public void setPrice(double price) {
        this.price = price;
    }
    public int getRecordStatus() {
        return recordStatus;
    }
    public void setRecordStatus(int recordStatus) {
        this.recordStatus = recordStatus;
    }
}

ItemGroup.java

package com.thiha.entities;

import java.util.List;
import javax.persistence.CascadeType;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.OneToMany;

@Entity
public class ItemGroup {

    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    private Integer id;
    private String createdDate;
    private String modifiedDate;
    private String groupCode;
    private String groupName;
    private int recordStatus;
    private List<Item> items;

    @OneToMany(mappedBy = "itemGroup", cascade = CascadeType.ALL)
    public List<Item> getItems(){
        return items;
    }

    public Integer getId() {
        return id;
    }
    public void setId(Integer id) {
        this.id = id;
    }
    public String getCreatedDate() {
        return createdDate;
    }
    public void setCreatedDate(String createdDate) {
        this.createdDate = createdDate;
    }
    public String getModifiedDate() {
        return modifiedDate;
    }
    public void setModifiedDate(String modifiedDate) {
        this.modifiedDate = modifiedDate;
    }
    public String getGroupCode() {
        return groupCode;
    }
    public void setGroupCode(String groupCode) {
        this.groupCode = groupCode;
    }
    public String getGroupName() {
        return groupName;
    }
    public void setGroupName(String groupName) {
        this.groupName = groupName;
    }
    public int getRecordStatus() {
        return recordStatus;
    }
    public void setRecordStatus(int recordStatus) {
        this.recordStatus = recordStatus;
    }
}

我还在 Item 表中创建了一个外键,引用具有外键 groupid 的 ItemGroup 表。但是当我使用 mvn spring-boot:run 运行代码时,出现了一些异常,如下所示:

org.hibernate.MappingException: Could not determine type for: java.util.List, at table: item_group, for columns: [org.hibernate.mapping.Column(items)]
at org.hibernate.mapping.SimpleValue.getType(SimpleValue.java:431)
at org.hibernate.mapping.SimpleValue.isValid(SimpleValue.java:398)
at org.hibernate.mapping.Property.isValid(Property.java:225)
at org.hibernate.mapping.PersistentClass.validate(PersistentClass.java:595)
at org.hibernate.mapping.RootClass.validate(RootClass.java:265)
at org.hibernate.boot.internal.MetadataImpl.validate(MetadataImpl.java:329)
at org.hibernate.boot.internal.SessionFactoryBuilderImpl.build(SessionFactoryBuilderImpl.java:443)
at org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl.build(EntityManagerFactoryBuilderImpl.java:879)

如果我删除两个类中的关系,它可以正常工作,但我无法进行 INNER JOIN 查询。请帮我解决这个问题

最佳答案

您不能在 Hibernate 中混合注释约定。请尝试将您的 @Id@GenerateValue 注释移至 getter,或将 @OneToMany@ManyToOne 移至字段.

关于java - 使用 Spring Boot 的 Hibernate 上的表列映射错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41086594/

相关文章:

java - Android-Week-View 每周异步加载事件

java - 如何将 JSON 对象发布到 URL?

php - 我找不到的语法错误

java - Spring XmlBeanFactory 已弃用

java - 使用 Java 对不同时间间隔的时间条目进行求和和分类

php - Mysql 查询排除当前显示的项目

MySQL:找到 max(created_at),其中 another_column in (a,b,...)

java - CommonsRequestLoggingFilter 与 Logstash StructuredArgument 的使用

java - Spring MVC 表单处理如何工作?

java - 检查桌面应用程序是否已在运行