3

过去几天我一直在努力解决 linq 查询性能问题:

LinqConnectionDataContext context = new LinqConnectionDataContext();
System.Data.Linq.DataLoadOptions options = new System.Data.Linq.DataLoadOptions();
options.LoadWith<Question>(x => x.Answers);
options.LoadWith<Question>(x => x.QuestionVotes);
options.LoadWith<Answer>(x => x.AnswerVotes);
context.LoadOptions = options;
var query =( from c in context.Questions
            where c.UidUser == userGuid
            && c.Answers.Any() == true
            select new
            {
                c.Uid,
                c.Content,
                c.UidUser,
                QuestionVote = from qv in c.QuestionVotes where qv.UidQuestion == c.Uid && qv.UidUser == userGuid select new {qv.UidQuestion, qv.UidUser },
                Answer = from d in c.Answers
                         where d.UidQuestion == c.Uid
                         select new
                         {
                             d.Uid,
                             d.UidUser,
                             d.Conetent,
                             AnswerVote = from av in d.AnswerVotes where av.UidAnswer == d.Uid && av.UidUser == userGuid select new { av.UidAnswer, av.UidUser }
                         }
            }).ToList();

查询必须运行 5000 行,最多需要 1 分钟。如何提高此查询的性能?

更新:

在此处输入图像描述

4

2 回答 2

1

使用sql-debug-visualizer检查生成的 sql ,然后复制生成的 SQL 并从 SQL 客户端运行它,看看它需要多少时间。如果需要将近 1 分钟,您需要通过添加索引和/或存储过程或创建视图等来提高 DB 级别的性能。

如果上面不需要太多时间,您总是可以创建存储过程并使用 LINQ to SQ L调用它。

如果您可以更改为,另一项建议是使用实体框架,因为它是未来。

于 2012-10-17T12:12:18.980 回答
1

让你开始的东西。

CREATE PROCEDURE GetQuestionsAndAnswers
(
    @UserGuid VARCHAR(100)
)
AS
BEGIN

SELECT 
c.Uid, 
c.Content, 
c.UidUser, 
qv.UidQuestion, 
qv.UidUser, 
av.UidAnswer, 
av.UidUser, 
av.Content,
d.Uid,
d.UidUser,
d.Content
FROM Question c
INNER JOIN QuestionVotes qv ON qv.UidQuestion = c.Uid AND qv.UidUser = @UserGuid
INNER JOIN Answers d ON d.UidQuestion = c.Uid
INNER JOIN AnswerVotes av ON av.UidAnswer = d.Uid AND av.UidUser = @UserGuid
WHERE c.UidUser = @UserGuid

END

默认情况下,您已经在主列上拥有聚集索引(只需在数据库端确认这一点),并且您希望在 QuestionVote - UidUser 列、AnswerVote - UidUser 列和 Answer - UidQuestion 列上使用非聚集索引。

也看看这里。您可能希望使用.AsQueryable()而不是ToList()延迟执行

你 ToList() 吗?

于 2012-10-17T12:21:12.353 回答