sql >> Databasteknik >  >> RDS >> Mysql

Hur fyller man i främmande nyckelvärden i en Hibernate + Spring JPA-konfiguration när överordnade/underordnade objekt finns kvar samtidigt?

Den koden har två saker som hindrar den från att fungera:

  1. Dina enheter har ingen @Id . Du har förmodligen bara lämnat det eftersom det här är ett exempel, men det är värt att påpeka.
  2. Du har dubbelmappat kolumnen parent_id . Underbarn har både ett långt fält och ett överordnat fält mappat till samma kolumn. Bli av med det långa. Det är föräldrarelationen du är ute efter.

Efter det, vad du har där är en helt traditionell dubbelriktad en-till-många med en sammanfogningskolumn. Om det inte fungerar för dig gör du något fel i koden där du skapar och sparar dem. Mycket troligt skapar du inte objekten ordentligt. Korrekt kod med dessa enheter skulle se ut ungefär så här:

Session session = sessionFactory.openSession();
Transaction tx = session.beginTransaction();
Parent p = new Parent();
Child child = new Child();
child.parent = p;
Child child1 = new Child();
child1.parent = p;
p.children = Arrays.asList(child, child1);
session.save(p);
session.save(p.children.get(0));
session.save(p.children.get(1));
tx.commit();

Observera särskilt att barnet ska vara inställt i föräldern såväl som föräldern i barnet. Bygg inte en halvtrasig objektmodell och förvänta dig att Hibernate ska städa upp i din röra. Många människor ignorerar detta till synes uppenbara krav och undrar varför Hibernate verkar instabilt och/eller opålitligt.




  1. Python SQL – Hur man använder SQLite-, MySQL- och PostgreSQL-databaserna med Python

  2. Få avancerade anpassade fält repeaterfältvärde baserat på ett annat repeatervärde

  3. Behöver MySQL-tabeller ett ID?

  4. Vad är en ODBC-kompatibel databas?