PersistenceException от простого CRUD для простого класса - PullRequest
1 голос
/ 24 марта 2011

Используя базу данных в памяти (db = mem), я просто пытаюсь вставить новый объект в базу данных, используя CRUD.

Класс выглядит следующим образом:

@Entity
public class ActivityModel extends Model {
    @Required
    public String description;

    @Required
    public String link;

    @Required
    public Date timestamp;

    public ActivityModel(String description, String link, Date timestamp) {
        this.description = description;
        this.link = link;
        this.timestamp = timestamp;
    }
}

И контроллеры CRUD выглядят так:

@CRUD.For(ActivityModel.class)
public class Activities extends CRUD {
}

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

13:48:20,710 INFO  ~ Application 'ScoreDB' is now started !
13:48:48,323 WARN  ~ SQL Error: -177, SQLState: 23000
13:48:48,323 ERROR ~ Integrity constraint violation - no parent FKF0DCD93AADF686FF table: USERMODEL in statement [insert into ActivityModel (id, description, link, timestamp) values (null, ?, ?, ?)]
13:48:48,370 ERROR ~ 

@65pagp52g
Internal Server Error (500) for request POST /admin/activities

Execution exception (In {module:crud}/app/controllers/CRUD.java around line 135)
PersistenceException occured : org.hibernate.exception.ConstraintViolationException: could not insert: [models.users.hidden.ActivityModel]

play.exceptions.JavaExecutionException: org.hibernate.exception.ConstraintViolationException: could not insert: [models.users.hidden.ActivityModel]
    at play.mvc.ActionInvoker.invoke(ActionInvoker.java:290)
    at Invocation.HTTP Request(Play!)
Caused by: javax.persistence.PersistenceException: org.hibernate.exception.ConstraintViolationException: could not insert: [models.users.hidden.ActivityModel]
    at org.hibernate.ejb.AbstractEntityManagerImpl.convert(AbstractEntityManagerImpl.java:1235)
    at org.hibernate.ejb.AbstractEntityManagerImpl.convert(AbstractEntityManagerImpl.java:1168)
    at org.hibernate.ejb.AbstractEntityManagerImpl.convert(AbstractEntityManagerImpl.java:1174)
    at org.hibernate.ejb.AbstractEntityManagerImpl.persist(AbstractEntityManagerImpl.java:674)
    at play.db.jpa.JPABase._save(JPABase.java:37)
    at controllers.CRUD.create(CRUD.java:135)
    at play.mvc.ActionInvoker.invokeControllerMethod(ActionInvoker.java:413)
    at play.mvc.ActionInvoker.invokeControllerMethod(ActionInvoker.java:408)
    at play.mvc.ActionInvoker.invoke(ActionInvoker.java:182)
    ... 1 more

... etc ...

Что такоеЯ делаю не так?: S

1 Ответ

1 голос
/ 29 марта 2011

Очевидно, это было потому, что был другой класс, содержащий следующий код:

@OneToMany(cascade = CascadeType.ALL, mappedBy="id")
public Collection<ActivityModel> activities;

В котором 'mappedBy = "id"' является источником проблемы.

Удалите это, и все это работает:)

...