Blog Home  Home Feed your aggregator (RSS 2.0)  
artiso Blog - Mit LINQ verknüpfte Tabellen in einem SELECT-Statement laden
Neues rund um's Thema .Net
 
 Wednesday, August 15, 2007

Ich habe folgendes Datenmodell mit dem LINQ To SQL Designer aufgebaut:

image

So, eigentlich ganz einfach. Mit folgendem Code kann ich die Daten einlesen:

    var formList = from f in listDataContext.cFormListItems
                   orderby f.FormShort                            
                   select f;
    var countryList = from c in listDataContext.cCountryListItems 
                      orderby c.CountryName 
                      select c;

Damit liest LINQ die Daten für die Forms bzw. die Countries ein, die zugeordneten Tabellen bleiben leer, bis man auf das entsprechende Element zugreift, dann wird das nachgeladen (lazy loading). Dieser Effekt ist super, wenn ich z.B. eine Liste der Kunden habe und den Kunden Bestellungen zugeordnet sind und ich teilweise Kunden mit mehreren tausend Bestellungen habe. Dann will ich die Bestellungen nicht gleich alle mitladen. Aber in meinem Fall war es so, dass in den verknüpften Tabellen nur wenige Datensätze stehen und ich deshalb lieber alles auf einen Rutsch laden wollte. Das geht dann so:

    listDataContext = new cListDataContext("Data Source=NOTEBOOK_VISTA;Initial Catalog=ValuePlanner_2008;Integrated Security=True");
    
    // Define LoadOptions to load some related tables with their parent tables in one select statement
    DataLoadOptions loadOptions = new DataLoadOptions();
    loadOptions.LoadWith<cFormListItem>(f => f.FormType);
    loadOptions.LoadWith<cCountryListItem>(c => c.Market);
    listDataContext.LoadOptions = loadOptions;

Diesen Code muss man vor der ersten Abfrage ausführen. Hier werden zwei LoadWith (jeweils für eine untergeordnete Tabelle) mit angegeben. Dies bewirkt, dass die untergeordneten Tabellen mit der jeweiligen Haupttabelle in einem einzigen SELECT Statement aus der Datenbank geladen werden! Ein paar Sachen muss man allerdings beachten:

  • Die LoadOptions können nur vor der ersten Abfrage auf dem DataContext zugewiesen werden.
  • Die Loadoptions können nicht mehr verändert werden, wenn sie einmal einem DataContext zugewiesen wurden.
  • Für mehrere Tabellen ruft man das LoadWith einfach mehrfach auf.

Ich hätte das zwar schöner gefunden, wenn man das auch mit im Designer einstellen könnte, aber es funktioniert einwandfrei.

Hier noch als Beweis das SQL-Statement, das dann tatsächlich auf der Datenbank ausgeführt wird:

SELECT [t0].[ID], [t0].[FormLong], [t0].[FormShort], [t0].[FormTypeID], [t1].[ID] AS [ID2], [t1].[FormTypeLong], [t1].[FormTypeShort]
FROM [values_Forms] AS [t0]
INNER JOIN [values_FormTypes] AS [t1] ON [t1].[ID] = [t0].[FormTypeID]
ORDER BY [t0].[FormShort]
Wednesday, August 15, 2007 6:17:42 PM (Mitteleuropäische Zeit, UTC+01:00)  #    Comments [0]    | 
All comments require the approval of the site owner before being displayed.
Name
E-mail
Home page

Comment (HTML not allowed)  

Enter the code shown (prevents robots):

Copyright © 2008 Thomas. All rights reserved.
DasBlog 'Portal' theme by Johnny Hughes.
Pick a theme: