Linq 的速度

hetengfei_ 2012-03-12 04:22:31
//不知下面的语句如何,会不会全表扫描?
var select =( from ps in user.TUsers
// where (ps.UserName.StartsWith("t"))
orderby ps.id descending
select new { id = ps.id.ToString(), name = ps.UserName, pass = ps.Password }).Skip(2).Take(5);


相比如下的sql语句 ?
select *from
(
select TUsers.id,TUsers.UserName,TUsers.Password,Row_Number()over(order by id desc) as rn, from TUsers
)as ps
where(ps.rn>=@Index and ps.rn<@Index+@Count)


哪个要快点? 因为这个 用户表的数据量很大,优化很重要 。
...全文
139 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
Im_Sorry 2012-03-12
  • 打赏
  • 举报
回复
那是相当的快!
hetengfei_ 2012-03-12
  • 打赏
  • 举报
回复
//下面这个就是那个linq 转换成的sql 语句。
大家看看,对比下,那个要好点。//我已把它小写化了,小写好看点

select [t2].[value] as [id2], [t2].[username] as [name], [t2].[password] as [pass]
from (
select row_number() over (order by [t1].[id] desc) as [row_number], [t1].[value], [t1].[username], [t1].[password]
from (
select convert(nvarchar(max),[t0].[id]) as [value], [t0].[username], [t0].[password], [t0].[id]
from [t_users] as [t0]
) as [t1]
) as [t2]
where [t2].[row_number] between @p0 + 1 and @p0 + @p1
order by [t2].[row_number]

骑猪看海 2012-03-12
  • 打赏
  • 举报
回复
调试时看下生成的SQL语句
tptptp00 2012-03-12
  • 打赏
  • 举报
回复
linq比lz的sql快
tptptp00 2012-03-12
  • 打赏
  • 举报
回复

select a.ID,a.Name from TUsers a
inner join (
select rownum,ID,Name,TypeID,BrandID from (select ROW_NUMBER() over(order by id) rownum,ID,Name,TypeID,BrandID
from TUsers ) t where rownum between 0 and 10) as b
on a.ID=b.ID order by b.rownum
挨踢直男 2012-03-12
  • 打赏
  • 举报
回复
linq不是转换成sql的吗?

那当然是直接用sql来的快
nfclass 2012-03-12
  • 打赏
  • 举报
回复
记录下前后时间 对比下嘛
种草德鲁伊 2012-03-12
  • 打赏
  • 举报
回复
其实这个都被吐糟过无数次了,linq跟数据库没直接关系
zh6335901 2012-03-12
  • 打赏
  • 举报
回复
你这语句不会全表扫描
tptptp00 2012-03-12
  • 打赏
  • 举报
回复
Sql Server Profiler

62,268

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧