1

私は Hibernate にかなり慣れていませんが、習得するのが簡単なテクノロジではないことがわかりました... プロジェクトでは、hibernate バージョン 4.2.0.CR1 を使用しています。すべてのデータベース エンティティの基本クラスを作成しようとしています。すべてのデータベース エンティティには、何らかの識別子と作成日が含まれているはずです。奇妙なのは、最初は基本クラスなしでクラス User と UserPicture を作成し、完全に正常に機能し、追加したので、以前と同じように機能するはずなのに、o_O にならず、スローし続けることです。以前はスローされなかった、私の写真のリストに関するいくつかの奇妙な例外...だから、私は次のスタックトレースを取得し続けます:

org.hibernate.MappingException: Could not determine type for: java.util.List, at table: User, for columns: [org.hibernate.mapping.Column(profilePicture)]
at org.hibernate.mapping.SimpleValue.getType(SimpleValue.java:314)
at org.hibernate.mapping.SimpleValue.isValid(SimpleValue.java:292)
at org.hibernate.mapping.Property.isValid(Property.java:239)
at org.hibernate.mapping.PersistentClass.validate(PersistentClass.java:469)
at org.hibernate.mapping.UnionSubclass.validate(UnionSubclass.java:61)
at org.hibernate.cfg.Configuration.validate(Configuration.java:1283)
at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1734)
at love.commons.database.DBManager.<init>(DBManager.java:28)
at love.commons.database.DBManagerTest.<clinit>(DBManagerTest.java:19)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:44)
at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:15)
at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:41)
at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:27)
at org.junit.runners.ParentRunner.run(ParentRunner.java:236)
at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:50)
at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:467)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197)

抽象エンティティ:

@Entity
@Inheritance(strategy = InheritanceType.TABLE_PER_CLASS)
public abstract class AbstractEntity implements Serializable{

private static final long serialVersionUID = 1L;

protected Long id;

protected Date creationDate = new Date();

@Id
@Column(name="id")
@GeneratedValue(strategy=GenerationType.TABLE)
public Long getId() {
    return id;
}

public void setId(Long id) {
    this.id = id;
}

@Column
@NotNull
@Temporal(TemporalType.DATE)
public Date getCreationDate() {
    return creationDate;
}

public void setCreationDate(Date creationDate) {
    this.creationDate = creationDate;
}
}

ユーザー:

@Entity
@Table(name="User")
public class User extends AbstractEntity {

private static final long serialVersionUID = 1L;

@Column (unique=true, length=30)
@NotNull
private String login;

@Column (length=32)
@NotNull
private String password;

@NotNull
@Email
@Column (unique=true, length=80)
private String email;

@OneToMany(cascade=CascadeType.ALL, fetch=FetchType.LAZY, mappedBy="owner")
private List<UserPicture> profilePictures = new LinkedList<UserPicture>();

public String getLogin() {
    return login;
}

public void setLogin(String login) {
    this.login = login;
}

public String getPassword() {
    return password;
}

public void setPassword(String password) {
    this.password = password;
}

public String getEmail() {
    return email;
}

public void setEmail(String email) {
    this.email = email;
}

@Transient
public void encryptPassword() {
    this.password = md5(password);
}

public List<UserPicture> getProfilePicture() {
    return Collections.unmodifiableList(profilePictures);
}

public void addProfilePicture(UserPicture profilePicture) {
    profilePicture.setOwner(this);
    profilePictures.add(profilePicture);
}

@Transient
private String md5(String input) {

    String md5 = null;

    if(null == input) return null;

    try {
        MessageDigest digest = MessageDigest.getInstance("MD5");
        digest.update(input.getBytes(), 0, input.length());
        md5 = new BigInteger(1, digest.digest()).toString(16);

    } catch (NoSuchAlgorithmException e) {

        e.printStackTrace();
    }
    return md5;
}   
}

ユーザー画像:

@Entity
public class UserPicture extends AbstractEntity {

private static final long serialVersionUID = 1L;

@Column(length=734004)
private byte [] picture = null;

@ManyToOne(fetch=FetchType.LAZY)
@Column(name="owner")
@JoinColumn(nullable=false,name="id")
private User owner;

public UserPicture() {
    picture = null;
}

public UserPicture(InputStream stream) {
    try {
        this.picture = new byte[stream.available()];
        stream.read(picture);
    } catch (IOException e) {
        e.printStackTrace();
    }
}

public UserPicture(byte [] picture) {
    this.picture = picture;
}

public byte[] getPicture() {
    return picture;
}

public void setPicture(byte[] picture) {
    this.picture = picture;
}

public User getOwner() {
    return owner;
}

public void setOwner(User owner) {
    this.owner = owner;
}   
}

それで、私は何を間違っていますか?例外が発生し続けるのはなぜですか?

4

4 に答える 4

6

@EntityAbstractEntity にand のアノテーションを付けてはなりません@Inheritance。で注釈を付ける必要があります@MappedSuperclass。実際、この継承は共通の属性を継承するためにのみ使用され、それMappedSuperclassが目的です。

発生する例外は、マッピング アノテーションの位置に一貫性がないことが原因です。基本スーパークラスはゲッターに注釈を付け、サブクラスはフィールドに注釈を付けます。Hibernate は Id アノテーションの位置を使用して、エンティティのアクセス タイプを決定します。@Id はゲッター上にあるため、ゲッターに配置されたアノテーションのみを考慮し、フィールドに配置されたアノテーションは無視します。すべての注釈をフィールド (これをお勧めします) またはゲッターに配置します。

さらに、ゲッターの名前が悪いです。であってはなりgetProfilePictures()ませんgetProfilePicture()

于 2013-04-20T07:44:14.223 に答える