首页 行业资讯 宠物日常 宠物养护 宠物健康 宠物故事
您的当前位置:首页正文

EF查询生成的SQL

2023-11-09 来源:好兔宠物网
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 N‘zhaokun‘=[Extent1].[Name]
sqlone

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

技术分享
1 using (var context = new MyDbContext())2 {3 var people = from p in context.People4 where p.PersonID > 1005 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

标签:

小编还为您整理了以下内容,可能对您也有帮助:

如何得到EF查询生成的SQL

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

using (var context = new MyDbContext())
{
    var people = from p in context.People
                 where p.PersonID > 100
                 select p;

    string sql = people.ToString();
}

所生成的SQL是:
SELECT 
[Extent1].[PersonID] AS [PersonID], 
[Extent1].[Name] AS [Name]
FROM [dbo].[People] AS [Extent1]
WHERE [Extent1].[PersonID] > 100
大 家应该已经猜到,这里的ToString()方法其实也就是调用了ObjectQuery<>的ToTraceString()方法。 DbQuery<>.ToString() ==> System.Data.Entity.Internal.Linq.InternalQuery<>.ToString()方法,此方法 在.NET Reflector得到的实现是这样的:
public override string ToString()
{
    return this._objectQuery.ToTraceString();
}

如何得到EF查询生成的SQL

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

using (var context = new MyDbContext())
{
    var people = from p in context.People
                 where p.PersonID > 100
                 select p;

    string sql = people.ToString();
}

所生成的SQL是:
SELECT 
[Extent1].[PersonID] AS [PersonID], 
[Extent1].[Name] AS [Name]
FROM [dbo].[People] AS [Extent1]
WHERE [Extent1].[PersonID] > 100
大 家应该已经猜到,这里的ToString()方法其实也就是调用了ObjectQuery<>的ToTraceString()方法。 DbQuery<>.ToString() ==> System.Data.Entity.Internal.Linq.InternalQuery<>.ToString()方法,此方法 在.NET Reflector得到的实现是这样的:
public override string ToString()
{
    return this._objectQuery.ToTraceString();
}

如何查看ef6生成的sql语句

可以使用ToTraceString()方法得到EF查询所生成的SQL。

using (var context = new TestDBEntities())  
{      
var query = from p in context.Parents                  
where p.Name == "Ling"                  
select p;       
ObjectQuery<Parent> parents = query as ObjectQuery<Parent>;      
if (parents != null)      
{          
string sql = parents.ToTraceString();      
}  
}

 

这里所生成的SQL为:

 SELECT   [Extent1].[ParentID] AS [ParentID], 
[Extent1].[Name] AS [Name]  
FROM [dbo].[Parent] AS [Extent1]  
WHERE N'Ling'=[Extent1].[Name]

如何查看ef6生成的sql语句

可以使用ToTraceString()方法得到EF查询所生成的SQL。

using (var context = new TestDBEntities())  
{      
var query = from p in context.Parents                  
where p.Name == "Ling"                  
select p;       
ObjectQuery<Parent> parents = query as ObjectQuery<Parent>;      
if (parents != null)      
{          
string sql = parents.ToTraceString();      
}  
}

 

这里所生成的SQL为:

 SELECT   [Extent1].[ParentID] AS [ParentID], 
[Extent1].[Name] AS [Name]  
FROM [dbo].[Parent] AS [Extent1]  
WHERE N'Ling'=[Extent1].[Name]

如何查看EF 生成的sql语句

添加 引用:
using System.Data.Objects;

var results = db.tb_proct.Where(s => s.ID == 2160);
var sql = (results as ObjectQuery<tb_proct>).ToTraceString();

在EF4.1中,可以直接 使用 ToString()

using (var context = new MyDbContext())
{
var people = from p in context.People
where p.PersonID > 100
select p;

string sql = people.ToString();
}

如何查看EF 生成的sql语句

添加 引用:
using System.Data.Objects;

var results = db.tb_proct.Where(s => s.ID == 2160);
var sql = (results as ObjectQuery<tb_proct>).ToTraceString();

在EF4.1中,可以直接 使用 ToString()

using (var context = new MyDbContext())
{
var people = from p in context.People
where p.PersonID > 100
select p;

string sql = people.ToString();
}

ef使用sql语句查询单个数据,比如我要查询某表里面的某一个值,该怎么用。谢谢大神

declare

varchar temp(10)

select @temp=z from DB:A where ...

if(@temp==1)

select * from DB:B where...

else if(@temp==2)

select * from DB:C where...

else if(@temp==3)

select * from DB:D where...

这个思路应该是这样的,你自己把代码补充完整,数据类型定好,希望能帮到你追问大哥,我可能没有描述清楚,我的意思是说,在.net MVC 里面使用一个叫做Entity Framework 的框架,怎么用sql语句查询单行单列的数据。

不过还是谢谢你。

如何在EF中直接运行SQL命令

相信不少使用EF的同志们已经知道如何在EF中运行SQL命令了。我在这里简单总结下,希望对大家学习EF有所帮助!

在 EF第一个版本(.NET 3.5 SP1)中,我们只能通过将ObjectContext.Connection转换为EntityConnection,再把 EntityConnection.StoreConnection转换为SqlConnection。有了这个SqlConnection,我们再创建 SqlCommand便能顺利运行SQL命令了。(个人觉得其实很烦,呵呵)

例如:

EntityConnection entityConnection = (EntityConnection)ctx.Connection;

DbConnection storeConnection = entityConnection.StoreConnection;

DbCommand cmd = storeConnection.CreateCommand();

cmd.CommandType = System.Data.CommandType.StoredProcere;

cmd.CommandText = "[PRO_USER_DIGITALCARD_CHECK]";

。。。。。。。

在EF4(.NET 4)中,我们有了全新的API:ObjectContext.ExecuteStoreCommand(...)和 ObjectContext.ExecuteStoreQuery<T>(...)。从函数名不难知道前者是为了执行某一并无返回集的SQL 命令,例如UPDATE,DELETE操作;后者是执行某一个查询,并可以将返回集转换为某一对象。

using (var ctx = new MyObjectContext())

{

ctx.ExecuteStoreCommand("UPDATE Person SET Name = 'Michael' WHERE PersonID = 1");

}

using (var ctx = new MyObjectContext())

{

var peopleViews = ctx.ExecuteStoreQuery<PersonView>("SELECT PersonID, Name FROM Person");

}

public class PersonView

{

public int PersonID { get; set; }

public string Name { get; set; }

}

现在有了EF4.1,API的名字又有了些许改变。如果说DbContext将ObjectContext做了包装,那么DbContext.Database就是对应于数据库端信息的封装。执行SQL命令也自然从Database类型开始。对应于ExecuteStoreCommand和ExecuteStoreQuery<T>的是Database.ExecuteSqlCommand和Database.SqlQuery<T>。

using (var ctx = new MyDbContext())

{

ctx.Database.ExecuteSqlCommand("UPDATE Person SET Name = 'Michael' WHERE PersonID = 1");

}

using (var ctx = new MyDbContext())

{

var peopleViews = ctx.SqlQuery<PersonView>("SELECT PersonID, Name FROM Person").ToList();

}

public class PersonView

{

public int PersonID { get; set; }

public string Name { get; set; }

}

显示全文