Play framework 2.0 Java - 定义模型错误和initial-data.yml

时间:2012-04-03 11:08:41

标签: playframework-2.0

我正在尝试构建自己的模型并通过initial-data.yml填充它。

这里是:

#Artists

artists:

    - !!models.Artist
        id: 1
        name: orelsan
        occupation: chanteur

#Records
records:
    - !!models.Record
        id: 1
        title: Le chant des sirenes
        vinylType: La classe
        pressInfo: a
        style: rap
        hits: 11
        artist: !!models.Artist
                    id: 1

描述模型的不同java文件:Record.java -

@Entity
public class Record extends Model{

    @Id
    public Long id;

    @Required
    public String title;

    public String vinylType;

    public String pressInfo;

    public String style;

    @ManyToOne
    public Artist artist;

    public int hits;//Number of time played-consulted

    /**
     * Generic query helper for entity record with id Long
     */
    public static Finder<Long,Record> find = new Finder<Long, Record>(Long.class, Record.class);
}

Artist.java -

@Entity
public class Artist extends Model{

    @Id
    public Long id;

    @Required
    public String name;

    @Required
    public String occupation;

    /**
     * Generic query helper for entity Computer with id Long
     */
    public static Finder<Long,Artist> find = new Finder<Long, Artist>(Long.class, Artist.class);

    public String toString(){
        return name;
    }

}

运行我的应用程序会给我以下异常:

play.api.UnexpectedException: Unexpected exception [PersistenceException: ERROR executing DML bindLog[] error[Referential integrity constraint violation: "FK_RECORD_ARTIST_1: PUBLIC.RECORD FOREIGN KEY(ARTIST_ID) REFERENCES PUBLIC.ARTIST(ID)"; SQL statement:\n insert into record (id, title, vinyl_type, press_info, style, hits, artist_id) values (?,?,?,?,?,?,?) [23506-158]]]
    at play.core.ReloadableApplication$$anonfun$get$1$$anonfun$apply$3$$anonfun$1.apply(ApplicationProvider.scala:134) ~[play_2.9.1.jar:2.0]
    at play.core.ReloadableApplication$$anonfun$get$1$$anonfun$apply$3$$anonfun$1.apply(ApplicationProvider.scala:112) ~[play_2.9.1.jar:2.0]
    at scala.Option.map(Option.scala:133) ~[scala-library.jar:0.11.2]
    at play.core.ReloadableApplication$$anonfun$get$1$$anonfun$apply$3.apply(ApplicationProvider.scala:112) ~[play_2.9.1.jar:2.0]
    at play.core.ReloadableApplication$$anonfun$get$1$$anonfun$apply$3.apply(ApplicationProvider.scala:110) ~[play_2.9.1.jar:2.0]
    at scala.Either$RightProjection.flatMap(Either.scala:277) ~[scala-library.jar:0.11.2]
Caused by: javax.persistence.PersistenceException: ERROR executing DML bindLog[] error[Referential integrity constraint violation: "FK_RECORD_ARTIST_1: PUBLIC.RECORD FOREIGN KEY(ARTIST_ID) REFERENCES PUBLIC.ARTIST(ID)"; SQL statement:\n insert into record (id, title, vinyl_type, press_info, style, hits, artist_id) values (?,?,?,?,?,?,?) [23506-158]]
    at com.avaje.ebeaninternal.server.persist.dml.DmlBeanPersister.execute(DmlBeanPersister.java:116) ~[ebean.jar:na]
    at com.avaje.ebeaninternal.server.persist.dml.DmlBeanPersister.insert(DmlBeanPersister.java:76) ~[ebean.jar:na]
    at com.avaje.ebeaninternal.server.persist.DefaultPersistExecute.executeInsertBean(DefaultPersistExecute.java:91) ~[ebean.jar:na]
    at com.avaje.ebeaninternal.server.core.PersistRequestBean.executeNow(PersistRequestBean.java:527) ~[ebean.jar:na]
    at com.avaje.ebeaninternal.server.core.PersistRequestBean.executeOrQueue(PersistRequestBean.java:557) ~[ebean.jar:na]
    at com.avaje.ebeaninternal.server.persist.DefaultPersister.insert(DefaultPersister.java:404) ~[ebean.jar:na]
Caused by: org.h2.jdbc.JdbcSQLException: Referential integrity constraint violation: "FK_RECORD_ARTIST_1: PUBLIC.RECORD FOREIGN KEY(ARTIST_ID) REFERENCES PUBLIC.ARTIST(ID)"; SQL statement:
insert into record (id, title, vinyl_type, press_info, style, hits, artist_id) values (?,?,?,?,?,?,?) [23506-158]
    at org.h2.message.DbException.getJdbcSQLException(DbException.java:329) ~[h2.jar:1.3.158]
    at org.h2.message.DbException.get(DbException.java:169) ~[h2.jar:1.3.158]
    at org.h2.message.DbException.get(DbException.java:146) ~[h2.jar:1.3.158]
    at org.h2.constraint.ConstraintReferential.checkRowOwnTable(ConstraintReferential.java:345) ~[h2.jar:1.3.158]
    at org.h2.constraint.ConstraintReferential.checkRow(ConstraintReferential.java:287) ~[h2.jar:1.3.158]
    at org.h2.table.Table.fireConstraints(Table.java:861) ~[h2.jar:1.3.158]

我真的不明白这是从哪里来的。我基本上将我的代码基于ZenTask示例。虽然它会起作用。

有人有想法吗?

由于

1 个答案:

答案 0 :(得分:0)

确保Global.java中的Ebean.save具有正确的顺序。从上面的例子中,我希望你能在记录之前保存艺术家