Поделиться через


Практическое руководство. Отображение созданного SQL

Для просмотра кода SQL, созданного для запросов, и изменения обработки используется свойство Log. Этот подход может быть полезен для понимания функциональных возможностей LINQ to SQL и для отладки конкретных проблем.

Пример

В следующем примере для отображения кода SQL в окне консоли перед его выполнением использовано свойство Log. Это свойство можно применять с командами выполнения запросов, вставки, обновления и удаления.

Строки из окна консоли — это то, что вы видите при выполнении кода Visual Basic или C#, который следует.

SELECT [t0].[CustomerID], [t0].[CompanyName], [t0].[ContactName], [t0].[ContactT  
itle], [t0].[Address], [t0].[City], [t0].[Region], [t0].[PostalCode], [t0].[Coun  
try], [t0].[Phone], [t0].[Fax]  
FROM [dbo].[Customers] AS [t0]  
WHERE [t0].[City] = @p0  
-- @p0: Input String (Size = 6; Prec = 0; Scale = 0) [London]  
-- Context: SqlProvider(Sql2005) Model: AttributedMetaModel Build: 3.5.20810.0  
AROUT  
BSBEV  
CONSH  
EASTC  
NORTS  
SEVES  
db.Log = Console.Out;
IQueryable<Customer> custQuery =
    from cust in db.Customers
    where cust.City == "London"
    select cust;

foreach(Customer custObj in custQuery)
{
    Console.WriteLine(custObj.CustomerID);
}
db.Log = Console.Out
Dim custQuery = _
    From cust In db.Customers _
    Where cust.City = "London" _
    Select cust

For Each custObj In custQuery
    Console.WriteLine(custObj.CustomerID)
Next

См. также