zoukankan      html  css  js  c++  java
  • .NET 4中Entity Framework 新增查询与优化

    外键支持(Foreign Keys)

    Entity Framework添加了对外键的支持。利用外键关联,您现在可以将外键属性包含在实体里,这样做可以简化诸如数据绑定、n-tier开发等关键方案的开发。您可以直接使用外键属性设置实体之间的关系:  

        using (BlogEntities ctx = new BlogEntities()) { 

            Post myPost 
    = new Post { 

                PostID 
    = 102

                PostName 
    = "Post Title"

                CreatedDate 
    = DateTime.Now, 

                PostContent 
    = "Post Content"

                BlogID 
    = 11 

            }; 

            ctx.Posts.AddObject(myPost); 

            ctx.SaveChanges(); 

        } 

    在这个例子里,即使BlogID == 11的这个Blog对象从未被装载,我们也可以直接把新建的myPost对象与这个Blog对象之间的关系通过外键关联起来。

    延迟加载支持(Lazy Loading)

    现在Entity Framework支持延迟加载。一个新的模型在VS2010中被创建的同时,提供延迟加载功能的实体也被生成出来。默认情况下这个功能是开启的,一个查询操作返回的实体对象并不会被马上加载,而是会在实际被使用的时候加载。举例来说,延迟加载意味着下面这个代码段里,每个Post对象会在实际被调用来打印PostName属性的时候被加载。

       using (var ctx = new BlogEntities()) {  
            
    foreach (var b in ctx.Blogs) {  
                Console.WriteLine(b.BlogName);  
                
    //请注意我们并未主动装载当前blog的posts  
                
    //EF会为我们延迟加载  
                foreach (var p in b.Posts)  
                    Console.WriteLine(p.PostName);  
            }  
        } 

    加入SQL语句LIKE的生成支持

    在EF4中,加入对于WHERE语句的字符串参数使用数据库的通配符的支持。例如下面的LINQ查询语句会被翻译成一个使用WHERE子句和LIKE语句,并使用‘%’通配符在所有的Blogs里搜索BlogName属性以‘Visual Studio’开头的Blog。

        var query = from b in ctx.Blogs  
                    
    where b.BlogName.StartsWith("Visual Studio")  
                    select b;    

    加入SQL语句IN的生成支持

    在EF4中,加入对于WHERE语句的参数多个值查询的支持。例如下面的LINQ查询语句会被翻译成一个使用WHERE子句和IN语句,并使用一个数组在所有的Blogs里搜索BlogName属性为"Visual"和"Studio"的所有数据。

        var query = from b in ctx.Blogs  
                    
    where new string[] { "Visual""Studio" }.Contains( b.BlogName)  
                    select b;   


     

  • 相关阅读:
    第三篇:个案管理师之工作内容篇-台湾最佳医院信息化及管理实践
    第二篇:个案管理师之执行篇-台湾最佳医院信息化及管理实践
    第一篇:个案管理师之概念篇-台湾最佳医院信息化及管理实践-
    电子病历编辑器功能点六级试题库
    南京都昌科技电子病历模板库清单
    都昌 DCWriter电子病历编辑器演示文档截屏
    关于编程,你知道吗?
    都昌时间轴控件功能说明
    电子病历,到底是用BS还是CS
    2014年沈阳 委预算管理医院院长与信息中心主任高级管理培训班
  • 原文地址:https://www.cnblogs.com/ejiyuan/p/1749368.html
Copyright © 2011-2022 走看看