您的位置: 首页 > 技术文档 > 网络编程 > Entity Framework 4.0新增对T-SQL的支持
20年来我得到的20条编程经验 回到列表 编程语言的发展趋势及未来方向 I
 Entity Framework 4.0新增对T-SQL的支持

作者:张磊_larry.zhang 时间: 2010-06-22 文档类型:转载 来自:博客园

Entity Framework 4.0新增对T-SQL的支持

EF4.0中新增了ExecuteStoreQuery,ExecuteStoreCommand,ExecuteFunction等方法,完美支持T-SQL

之前在EF中用Linq进行left join查询和报表数据查询简直是一场噩梦,以下代码就是例子:

Linq左连接查询N张表示例代码:

public List<Info> getMapUnitList(int MapId)
{
var var1 = from mu in epm.MapUnit
join us in epm.UnitStatus
on mu.Unit equals us.Unit into _UnitStatus
join cu in epm.ContractUnit
on mu.Unit equals cu.Unit into _ContractUnit
where mu.Map.MapId == MapId
select new Info()
{
map = mu.Map
mapstatus = null
mapunit = mu
unit = mu.Unitstatus = _UnitStatus.Select(a => a.Status).FirstOrDefault()
contract = _ContractUnit.Select(a => a.Contract).FirstOrDefault()
customer = null

boothtype = null
};
var var2 = from v1 in var1
join ms in epm.MapStatus
on new { map = v1.map, status = v1.status }
equals new { map = ms.Map, status = ms.Status } into _MapStatus
select new Info()
{
map = null
mapstatus = _MapStatus.FirstOrDefault()
mapunit = v1.mapunit
unit = v1.unit
status = v1.status
contract = v1.contract
customer = null
boothtype = null
};
var var3 = from v2 in var2
from ubtl in epm.UnitBoothType
where ubtl.Unit.UnitId == v2.unit.UnitId
join cc in epm.CustomerContract
on v2.contract equals cc.Contract into _CustomerContract
select new Info()
{
map = null
mapstatus = v2.mapstatus
mapunit = v2.mapunit
unit = v2.unit
status = v2.status
contract = v2.contract
customer = _CustomerContract.Select(a => a.Customer).FirstOrDefault()
boothtype = ubtl.BoothType
};
List<Info> infos = var3.ToList();
return infos;
}

后来加入了E-SQL,但还是和T-SQL有很大区别,我看到那一堆 as 和 it 就想给挖掉 :)

EF 4.0新增加了对T-SQL的支持,根据T-SQL语句查询结果集中的列名自动映射到返回类型的属性名

甚至连EDM文件不支持映射的sql_varent类型也可以自动转换了,代码如下:

ExecuteStoreQuery方法:

protected void Page_Load(object sender, EventArgs e)
{
ERPEntities erp = new ERPEntities();
string query = @" SELECT [BillPlanRule].[id] as BillID
,qu.UnitNumber
,[BeginDate]
,[EndDate]
,ft.value as FeeType
,f.value as Frequency
,[Price]
,[ActualPrice]
,[Fee]
FROM [BillPlanRule]
left join dbo.SysParameter as ft
on [BillPlanRule].[FeeType]=ft.guid
left join dbo.SysParameter as f
on [BillPlanRule].[Frequency]=f.guid
left join dbo.QuotationUnit as qu
on [BillPlanRule].[UGuid]=qu.guid
where uguid in (select guid from dbo.QuotationUnit
where QuotationGuid in (select guid from dbo.Quotation where id=3) )
order by BillID";
ObjectResult<SysParameter> result = erp.ExecuteStoreQuery<SysParameter>(query);
List<SysParameter> list = result.ToList();
}

public class SysParameter
{
public int? BillID { get; set; }
public DateTime? BeginDate { get; set; }
public DateTime? EndDate { get; set; }
public string FeeType { get; set; }
public string Frequency { get; set; }
public decimal? Price { get; set; }
}

其中FeeType和Frequency在数据库中的类型都为sql_varent

ExecuteStoreQuery方法调用时并不是实时连接数据库查询,而是在下一句result.ToList()时才真正去查询

此方法很适合做复杂查询和报表查询,如根据各种不同条件拼接sql字符串的查询

欢迎访问微软官网下载相关软件http://www.microsoft.com/zh/cn/default.aspx

 

出处:蓝色理想
责任编辑:bluehearts

◎进入论坛网络编程版块参加讨论

相关文章 更多相关链接
VS2010 Web项目的jQuery版本升级
VS2010- IntelliTrace(智能跟踪)
Visual Studio 2010是云产品吗?
Visual Studio 2010版本信息介绍
详解 vs2010 中自动执行属性
作者文章 更多作者文章
云计算带来的行业创新与应用
精英汇走进上海交大圆满结束
伦敦奥运和残奥会吉祥物设计
Adobe CS5发布会功能推新
永恒之塔杯CG创意设计大赛颁奖盛典
热门搜索:CSS Fireworks 设计比赛 网页制作 web标准 用户体验 UE photoshop Dreamweaver Studio8 Flash 手绘 CG
站点最新 站点最新列表
100个黑色名片设计欣赏
MSDN技术资源库改进预览
图标设计欣赏——icondoctor
Web Storage全解析
Photoshop制作音乐网站播放器
解读iPhone平台的设计思路
Web Design广告字体设计技巧
Visual Studio DSL 入门(四)
HTML 5 Video概述
Visual Studio DSL 入门(三)
栏目最新 栏目最新列表
Firefox的Jetpack扩展案例分析
阿里妈妈UED谈CSS Sprites技术
Photoshop中设计绿色时尚Web网站
操作Dom节点实现间歇滚动新闻
浏览器15年历史回顾
如何创建Firefox的Jetpack扩展
全透视:CSS Z-index 属性
用PS 3D工具绘制甜麦圈包装袋
悟道Web标准:让W3C标准兼容终端
悟道WEB标准:统一思想,遵循标准

蓝色理想版权申明:除部分特别声明不要转载,或者授权我站独家播发的文章外,大家可以自由转载我站点的原创文章,但原作者和来自我站的链接必须保留(非我站原创的,按照原来自一节,自行链接)。文章版权归我站和作者共有。

转载要求:转载之图片、文件,链接请不要盗链到本站,且不准打上各自站点的水印,亦不能抹去我站点水印。

特别注意:本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有,文章若有侵犯作者版权,请与我们联系,我们将立即删除修改。

本文暂时没有评论和评分

您的评论
用户名:  口令:
说明:输入正确的用户名和密码才能参与评论。如果您不是本站会员,你可以注册 为本站会员。
注意:文章中的链接、内容等需要修改的错误,请用报告错误,以利文档及时修改。
不评分 1 2 3 4 5
注意:请不要在评论中含与内容无关的广告链接,违者封ID
请您注意:
·不良评论请用报告管理员,以利管理员及时删除。
·尊重网上道德,遵守中华人民共和国的各项有关法律法规
·承担一切因您的行为而直接或间接导致的民事或刑事法律责任
·本站评论管理人员有权保留或删除其管辖评论中的任意内容
·您在本站发表的作品,本站有权在网站内转载或引用
·参与本评论即表明您已经阅读并接受上述条款
推荐文档 | 打印文档 | 评论文档 | 报告错误  
专业书推荐 更多内容
《Web标准设计》
闪魂-FlashCS4完美入门与案例精粹
Waver_h's华丽世界
Illustrator CS3质感绘画表现技法
《Flash短片轻松学》
《用户体验要素》
《JavaScript语言精粹》
作品集 更多内容

小喵一个 影视传媒网站界面 永艾视觉设计工作室 我的Q-Zone音乐专题的 爱枣报3周年t恤设计 爱枣报3周年t恤设计 游戏网站 韩超-简历-WEB U