私はLinq to Sql上の記事を読んで、これに出くわした:IQueryable <T>ラムダ式をSQL文字列に変換するAPIまたは拡張機能はありますか?
IQueryProvider provider = new QueryProvider(database.GetCommand, database.ExecuteQuery);
IQueryable<Product> source = new Queryable<Product>(provider, database.GetTable<Product>());
IQueryable<string> results = source.Where(product => product.CategoryID == 2)
.OrderBy(product => product.ProductName)
.Select(product => product.ProductName)
.Skip(5)
.Take(10);
著者その後、普通のSQLで結果の翻訳:
exec sp_executesql N'SELECT [t1].[ProductName]
FROM (
SELECT ROW_NUMBER() OVER (ORDER BY [t0].[ProductName]) AS [ROW_NUMBER], [t0].[ProductName]
FROM [dbo].[Products] AS [t0]
WHERE [t0].[CategoryID] > @p0
) AS [t1]
WHERE [t1].[ROW_NUMBER] BETWEEN @p1 + 1 AND @p1 + @p2
ORDER BY [t1].[ROW_NUMBER]',N'@p0 int,@p1 int,@p2 int',@p0=2,@p1=5,@p2=10
をそして私は「聖なる牛wouldn」、自分自身に考えました!デバッグ時にこれらの文字列を生成するIQueryableの拡張機能があればそれは素晴らしいでしょうか?
このようなことを聞いたことがある人は誰でも、正しい方向に向けることができますか?
ありがとうございます!
http://msdn.microsoft.com/en-us/library/bb386961.aspx – Servy
一般的な動作の背景については、http://msdn.microsoft.com/en-us/を参照してください。 /library/bb399342.aspx – AakashM