栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

如何将外部列表集成到原始SQL查询中作为LINQ原始SQL查询中的表联接

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

如何将外部列表集成到原始SQL查询中作为LINQ原始SQL查询中的表联接

如果您使用的是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似乎很难做到这一点,但是,正如我所说,如果提高性能是主要目标,那么这可能是一个选择。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/634443.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号