Which code segment should you use?

You use Microsoft Visual Studio 2010 and Microsoft .NET Framework 4 to create an application. The
application connects to a Microsoft SQL Server database. You use the ADO.NET LINQ to SQL model
to retrieve data from the database. The application contains the Category and Product entities, as
shown in the following exhibit.

You need to ensure that LINQ to SQL executes only a single SQL statement against the database. You
also need to ensure that the query retrieves the list of categories and the list of products. Which
code segment should you use?

You use Microsoft Visual Studio 2010 and Microsoft .NET Framework 4 to create an application. The
application connects to a Microsoft SQL Server database. You use the ADO.NET LINQ to SQL model
to retrieve data from the database. The application contains the Category and Product entities, as
shown in the following exhibit.

You need to ensure that LINQ to SQL executes only a single SQL statement against the database. You
also need to ensure that the query retrieves the list of categories and the list of products. Which
code segment should you use?

A.
Using dc As New NorthwindDataContext()
dc.ObjectTrackingEnabled = False
Dim categories As var = From c In dc.Categories _
Select c
For Each category As var In categories
Console.WriteLine(“{0} has {1} products”, category.CategoryName, category.Products.Count)
Next
End Using

B.
Using dc As New NorthwindDataContext()

dc.DeferredLoadingEnabled = False
Dim dlOptions As New DataLoadOptions()
dlOptions.LoadWith(Of Category)(Function(c As ) c.Products)
dc.LoadOptions = dlOptions
Dim categories As var = From c In dc.Categories _
Select c
For Each category As var In categories
Console.WriteLine(“{0} has {1} products”, category. CategoryName, category.Products.Count)
Next
End Using

C.
Using dc As New NorthwindDataContext()
dc.DefferredLoadingEnabled = False
Dim categories As var = From c In dc.Categories _
Select c
For Each category As var In categories
Console.WriteLine(“{0} has {1} products”, category.CategoryName, category.Products.Count)
Next
End Using

D.
Using dc As New NorthwindDataContext()
dc.DeferredLoadingEnabled = False
Dim dlOptions As New DataLoadOptions()
dlOptions.Asso ciateWith(Of Category)(Function(c As ) c.Products)
dc.LoadOptions = dlOptions
Dim categories As var = From c In dc.Categories _
Select c
For Each category As var In categories
Console.WriteLine(“{0} has {1} products”, category.CategoryName, category.Products.Count)
Next
End Using

Explanation:
DataLoadOptions Class Provides for immediate loading and filtering of related data.
DataLoadOptions.LoadWith(LambdaExpression) Retrieves specified data related to the main target
by using a lambda expression.
You can retrieve many objects in one query by using LoadWith.
DataLoadOptions.AssociateWith(LambdaExpression) Filters the objects retrieved for a particular
relationship.
Use the AssociateWith method to specify sub-queries to limit the amount of retrieved data.
DataLoadOptions Class
(http://msdn.microsoft.com/en-us/library/system.data.linq.dataloadoptions.aspx)
How to: Retrieve Many Objects At Once (LINQ to SQL)
(http://msdn.microsoft.com/en-us/library/Bb386917(v=vs.90).aspx)
How to: Filter Related Data (LINQ to SQL)
(http://msdn.microsoft.com/en-us/library/Bb882678(v=vs.100).aspx)



Leave a Reply 0

Your email address will not be published. Required fields are marked *