将表行映射到Hibernate 4中的枚举值

时间:2014-12-03 05:57:40

标签: java orm enums hibernate-4.x

我有一个表roles,其中包含adminuser等值。我不想将其设为ENUM类型,因为我认为该列表可能会在不久的将来增长,缩小或改变。当我得到查询对象时,我无法想办法让Hibernate自动地直接映射到我们代码中各自的枚举类型。

对此有标准方法吗?

编辑:基本上,不是将字符串存储在行中(这是数据库中的内容),我希望它在查询数据库时存储枚举。

public class enum UserType {
Admin("Admin"),
User("User");

private final String userType;

UserType(String userType) {
    this.userType = userType;
}

@Override
public String toString() {
    return userType;
}
}
@Entity
@Table(name = "user")
public class User {
    private Int id;
    private UserType userType;

public Int getId() {
    return id;
}
public void setId(Int id) {
    this.id = id;
}
public UserType getUserType() {
    return userType;
}
public void setUserType(UserType userType) {
    this.userType = userType;
}

}

1 个答案:

答案 0 :(得分:0)

因为没有提供代码所以我会假设您想要由管理员或用户查询数据?

您可以创建一个角色枚举,然后将其包含在您的实体类中。

e.g。

枚举1:

public enum CardSuit implements Serializable{

        DIAMOND("Diamond"),HEART("Heart"),SPADE("Spade"),CLUB("Club");

        private String cardSuit;

        private CardSuit(String cardSuit){
            this.cardSuit = cardSuit;
        }

        public String toString(){
            return cardSuit;
        }

    }   

枚举2:

public enum CardValue implements Serializable{

    ACE(1),TWO(2),THREE(3),FOUR(4),
    FIVE(5),SIX(6),SEVEN(7),EIGHT(8),
    NINE(9),TEN(10),JACK(10),QUEEN(10),KING(10);

    private int cardValue;

    private CardValue (int cardValue){
        this.cardValue = cardValue;
    }

    public int getValue(){
        return cardValue;
    }

    public String toString(){
        return String.valueOf(cardValue);
    }

}

这是我如何映射枚举类型。

@Entity
@Table(name="CARD")
public class Card implements Serializable{

    private static final long serialVersionUID = 1L;

    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    @Column(name="CARD_ID")
    private int cardId;

    @Enumerated(EnumType.STRING)
    @Column(name="CARD_VALUE")
    private CardValue cardValue;

    @Enumerated(EnumType.STRING)
    @Column(name="CARD_SUIT")
    private CardSuit cardSuit;

    //Setter & Getter ...

}

如果您了解Hibernate中的Criteria

这是通过枚举查询卡的示例:

sessionFactory.getCurrentSession()
            .createCriteria(Card.class)
            .add(Restrictions.eq("cardValue", CardValue.ACE))
            .list();