NET 4中Entity Framework 新增查询与优化
来源:互联网 发布:怎么淘宝做考试用书 编辑:程序博客网 时间:2024/05/15 15:11
外键支持(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();
}
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);
}
}
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;
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;
where new string[] { "Visual", "Studio" }.Contains( b.BlogName)
select b;
- .NET 4中Entity Framework 新增查询与优化
- NET 4中Entity Framework 新增查询与优化
- ADO.NET Entity Framework ESQL查询语句
- ASP.NET 4.0 与 Entity Framework 4-第三篇-使用Entity Framework调用存储过程
- ASP.NET 4.0 与 Entity Framework 4-第二篇-使用Entity Framework 进行CRUD操作
- ASP.NET 4.0 与 Entity Framework 4-第四篇-Entity Framework在三层架构中的使用
- ASP.NET 4.0 与 Entity Framework 4-第二篇-使用Entity Framework 进行CRUD操作
- ADO.NET Entity Framework 4.0 的新增功能
- Entity Framework的查询与操作
- Entity Framework的查询与操作
- Entity Framework(3)新增
- .net Entity Framework + mysql 使用中常见问题
- Entity Framework 动态查询
- entity framework 内联查询
- Entity Framework 简单查询
- Entity Framework 查询
- Entity framework查询原理
- Entity+Framework 优化相关
- LINQ to Entities 实现sql 关键字"In"方式总结
- vi高级应用
- 不同窗体间,不同Graphics对象绘图,有影响?
- 高斯消元解xor方程 poj1830
- 统计指定文件夹下指定文件类型的行数(java实现)
- NET 4中Entity Framework 新增查询与优化
- Flex3+ArcGIS+API改变导航条的样式
- Toyota Taps Salesforce CRM Technology to Link Customers to Their Cars
- Exception in thread "main" java.util.InputMismatchException
- linux下编写的中文注释在sourse insight中正确显示
- 冒泡排序
- ARM指令集-协处理器指令详解
- 二叉树求深度的递归的详细分析
- 透明窗体的又一实现