У меня есть две таблицы, как показано на следующей диаграмме:
, как вы видели, это очень простой пример, код SQL, относящийся к этому:
CREATE TABLE mere (
idmere INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
nom VARCHAR(50) NOT NULL,
PRIMARY KEY(idmere)
);
CREATE TABLE fil (
idfil INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
mere_idmere INTEGER UNSIGNED NOT NULL,
nom VARCHAR(50) NOT NULL,
PRIMARY KEY(idfil, mere_idmere),
FOREIGN KEY(mere_idmere)
REFERENCES mere(idmere)
ON DELETE NO ACTION
ON UPDATE NO ACTION
);
СNetbeans Я создал две сущности и два JpaController (связанных с созданными сущностями):
при вставке новых строк я получил эту ошибку (но новая строка вставляется только в таблицу Mere):
Grave: null
java.lang.NullPointerException
at testvirugule.FilJpaController.create(FilJpaController.java:37)
at testvirugule.Main.main(Main.java:35)
ОБНОВЛЕНИЕ
мой новый исходный код:
EntityManagerFactory emf=Persistence.createEntityManagerFactory("testvirugulePU");
MereJpaController mjc=new MereJpaController(emf);
FilJpaController fjc=new FilJpaController(emf);
Mere m=new Mere(null,"mere1");
FilPK fpk=new FilPK();
Fil f=new Fil(fpk,"fils1");
java.util.List<Fil> lf=new ArrayList<Fil>();
lf.add(f);
m.setFilList(lf);
mjc.create(m);
но я получаю эту ошибку:
Exception in thread "main" javax.persistence.EntityNotFoundException: Could not find entity for id: testvirugule.FilPK[ idfil=0, mereIdmere=0 ]
at org.eclipse.persistence.internal.jpa.EntityManagerImpl.getReference(EntityManagerImpl.java:1279)
at testvirugule.MereJpaController.create(MereJpaController.java:44)
at testvirugule.Main.main(Main.java:31)
Java Result: 1
какисправить эту проблему?спасибо.