Композитный ключ - Hibernate - PullRequest
0 голосов
/ 12 ноября 2018

У меня есть таблица ГРОБЕЙ, которая имеет следующую структуру:

CREATE TABLE grocery 
( 
     gro_id           NUMBER, 
     gro_name         VARCHAR(32), 
     gro_dep_name     VARCHAR(32), 
     gro_price        NUMBER(16, 2), 
     gro_max_discount NUMBER(16, 2), 
     CONSTRAINT gro_pk PRIMARY KEY (gro_id, gro_dep_name) 
  )

Моя проблема в том, что, когда я пытаюсь получить данные из таблицы (сохраненной в моей базе данных Oracle), я получаю следующую ошибку:

org.hibernate.id.IdentifierGenerationException: создан нулевой идентификатор для: класс com.domain.Grocery

Я сгенерировал следующие классы сущностей в соответствии со структурой таблицы:

Grocery.java

package com.domain;

import java.math.BigDecimal;
import javax.persistence.AttributeOverride;
import javax.persistence.AttributeOverrides;
import javax.persistence.Column;
import javax.persistence.EmbeddedId;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Table;

/**
 * Grocery generated by hbm2java
 */
@SuppressWarnings("serial")
@Entity
@Table(name = "GROCERY", schema = "TPRDBA")
public class Grocery implements java.io.Serializable {

    @EmbeddedId
    private GroceryId id;
    private String groName;
    private BigDecimal groPrice;
    private BigDecimal groMaxDiscount;

    public Grocery() {
    }

    public Grocery(GroceryId id) {
        this.id = id;
    }

    public Grocery(GroceryId id, String groName, BigDecimal groPrice, BigDecimal groMaxDiscount) {
        this.id = id;
        this.groName = groName;
        this.groPrice = groPrice;
        this.groMaxDiscount = groMaxDiscount;
    }

    @EmbeddedId
    @AttributeOverrides({
            @AttributeOverride(name = "groId", column = @Column(name = "GRO_ID", nullable = false, precision = 22, scale = 0)),
            @AttributeOverride(name = "groDepName", column = @Column(name = "GRO_DEP_NAME", nullable = false, length = 32)) })
    public GroceryId getId() {
        return this.id;
    }

    public void setId(GroceryId id) {
        this.id = id;
    }
    @Column(name = "GRO_NAME", length = 32)
    public String getGroName() {
        return this.groName;
    }
    public void setGroName(String groName) {
        this.groName = groName;
    }
    @Column(name = "GRO_PRICE", precision = 16)
    public BigDecimal getGroPrice() {
        return this.groPrice;
    }
    public void setGroPrice(BigDecimal groPrice) {
        this.groPrice = groPrice;
    }
    @Column(name = "GRO_MAX_DISCOUNT", precision = 16)
    public BigDecimal getGroMaxDiscount() {
        return this.groMaxDiscount;
    }
    public void setGroMaxDiscount(BigDecimal groMaxDiscount) {
        this.groMaxDiscount = groMaxDiscount;
    }
}

GroceryId.java

package com.domain;
// Generated Nov 12, 2018 11:42:16 AM by Hibernate Tools 4.3.1.Final

import java.math.BigDecimal;
import javax.persistence.Column;
import javax.persistence.Embeddable;

/**
 * GroceryId generated by hbm2java
 */
@SuppressWarnings("serial")
@Embeddable
public class GroceryId implements java.io.Serializable {


    private BigDecimal groId;
    private String groDepName;

    public GroceryId() {
    }

    public GroceryId(BigDecimal groId, String groDepName) {
        this.groId = groId;
        this.groDepName = groDepName;
    }

    @Column(name = "GRO_ID", nullable = false, precision = 22, scale = 0)
    public BigDecimal getGroId() {
        return this.groId;
    }

    public void setGroId(BigDecimal groId) {
        this.groId = groId;
    }

    @Column(name = "GRO_DEP_NAME", nullable = false, length = 32)
    public String getGroDepName() {
        return this.groDepName;
    }

    public void setGroDepName(String groDepName) {
        this.groDepName = groDepName;
    }

    public boolean equals(Object other) {
        if ((this == other))
            return true;
        if ((other == null))
            return false;
        if (!(other instanceof GroceryId))
            return false;
        GroceryId castOther = (GroceryId) other;

        return ((this.getGroId() == castOther.getGroId()) || (this.getGroId() != null && castOther.getGroId() != null
                && this.getGroId().equals(castOther.getGroId())))
                && ((this.getGroDepName() == castOther.getGroDepName())
                        || (this.getGroDepName() != null && castOther.getGroDepName() != null
                                && this.getGroDepName().equals(castOther.getGroDepName())));
    }

    public int hashCode() {
        int result = 17;

        result = 37 * result + (getGroId() == null ? 0 : this.getGroId().hashCode());
        result = 37 * result + (getGroDepName() == null ? 0 : this.getGroDepName().hashCode());
        return result;
    }

}

Я следовал этому примеру . Пожалуйста, помогите мне, я не могу понять, что в этом плохого.

Ниже приводится мой сервис для получения данных из базы данных, в которой есть GroceryRepository, расширяющий CrudRepository:

@Service
public class GroceryService {

    @Autowired
    GroceryRepository groceryRepository;

    public List<Grocery> getAllGrocery()
    {
        List<Grocery> groceries = new ArrayList<>();
        groceryRepository.findAll().forEach(groceries::add);
        return groceries;
    }

    public void addGrocery(Grocery grocery)
    {
        groceryRepository.save(grocery);
    }
}

Ответы [ 2 ]

0 голосов
/ 12 ноября 2018

Просто используйте @ EmbeddedId. При использовании аннотации EmbeddedId должна быть только одна аннотация EmbeddedId и не должна быть Id.

@EmbeddedId
 private GroceryId id;
0 голосов
/ 12 ноября 2018

Пропущена аннотация @EmbeddedId в Grocery.java. Обновите ваш код, как показано ниже.

 @EmbeddedId
 private GroceryId id;
...