码迷,mamicode.com
首页 > 数据库 > 详细

EF查询生成的SQL

时间:2015-07-17 20:49:07      阅读:595      评论:0      收藏:0      [点我收藏+]

标签:

在EF 4和EF 3.5 SP1中,我们可以使用ToTraceString()方法得到EF查询所生成的SQL。

技术分享
 1 using (var context = new TestDBEntities())
 2 {
 3     var query = from p in context.Parents
 4                 where p.Name == "zhaokun"
 5                 select p;
 6 
 7     ObjectQuery<Parent> parents = query as ObjectQuery<Parent>;
 8     if (parents != null)
 9     {
10         string sql = parents.ToTraceString();
11     }
12 }
totracestring

这里所生成的SQL为:

技术分享
1 [Extent1].[ParentID] AS [ParentID], 
2 [Extent1].[Name] AS [Name]
3 FROM [dbo].[Parent] AS [Extent1]
4 WHERE Nzhaokun=[Extent1].[Name]
sqlone

在EF 4.1中,我们可以直接调用DbQuery<>的ToString()方法得到所生成的SQL。

技术分享
1 using (var context = new MyDbContext())
2 {
3     var people = from p in context.People
4                  where p.PersonID > 100
5                  select p;
6 
7     string sql = people.ToString();
8 }
tostring

所生成的SQL是:

技术分享
1 SELECT 
2 [Extent1].[PersonID] AS [PersonID], 
3 [Extent1].[Name] AS [Name]
4 FROM [dbo].[People] AS [Extent1]
5 WHERE [Extent1].[PersonID] > 100
sqltwo

这里的ToString()方法其实也就是调用了ObjectQuery<>的ToTraceString()方法。 DbQuery<>.ToString() ==>  System.Data.Entity.Internal.Linq.InternalQuery<>.ToString()方法,此方法 在.NET Reflector得到的实现是这样的:

技术分享
1 public override string ToString()
2 {
3     return this._objectQuery.ToTraceString();
4 }
tostring()

看书得到!

EF查询生成的SQL

标签:

原文地址:http://www.cnblogs.com/zhaokunbokeyuan256/p/4655377.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!