Oracle
 sql >> Baza danych >  >> RDS >> Oracle

Nhibernate nie wstawia parentid do dziecka

Jeśli tak się stanie, na pewno przegapiłeś przypisanie obu stron relacji. Gdyby to miało miejsce:

var parent = ...;
var child = ...;
parent.Children.Add(child);
child.Parent = parent;

Wszystko będzie działać. Ponieważ najbardziej przypuszcza się, że Twój kod wygląda następująco:

var parent = ...;
var child = ...;
parent.Children.Add(child);
// child.Parent = parent; // this is missing

i to nie wstawi dzieci. Dlaczego?

Ponieważ użyliśmy .Inverse() mapowanie. To bardzo potężne, ale delikatne ustawienie. Pozwala NHibernate na wykonanie kilku ważnych optymalizacji, ale to wymaga - PARENT musi być ustawiony jako dziecko .

Sprawdź ten fajny artykuł

Inverse =„prawdziwy” przykład i wyjaśnienie przez mykong




  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Wyszukaj nazwę w cx_Oracle

  2. Załaduj ogromny plik csv do tabeli bazy danych Oracle za pomocą Pyspark

  3. Próbuję zbudować statyczny plik wykonywalny CGO z bibliotekami Oracle na Linux/Ubuntu

  4. Jak połączyć Oracle Database z projektem Visual Studio C#?

  5. wybierz * z nazwa_tabeli, gdzie kolumna, np. „ ”