如果您使用的是SQL Server 2008(或更高版本),并且提高性能是此处的主要目标(并且在这种情况下,您可能愿意放弃LINQ to
SQL),建议您将此查询编写为一个存储过程,以用户定义的表类型作为参数。这将使您可以将整个
sContentIds集合传递到数据库,并且仍然比临时查询还受益于存储过程的优势。
首先,将表类型定义为:
CREATE TYPE [dbo].[ContentList] AS TABLE( [ContentId] [int])
然后像下面这样创建过程:
CREATE PROCEDURE [dbo].[usp_GetContents] @contentIds ContentList READONLYASSELECt c.ContentId ,c.ContentPageId ,c.CreatedById ,p.PCA ,p.PCC ,p.PCD ,c.AlbumId , a.AlbumTypeId FROM Contents c INNER JOIN Privatizations p ON c.ContentId = p.ContentId LEFT JOIN Albums a ON c.AlbumId = a.AlbumIdWHERe c.ContentId IN (SELECt ContentId FROM @contentIds)
然后,您应该能够使用此答案中描述的技术从C#调用它(基本上是
DataTable从列表中创建一个,然后像常规参数一样添加它)。不幸的是,使用LINQtoSQL似乎很难做到这一点,但是,正如我所说,如果提高性能是主要目标,那么这可能是一个选择。



