Entity Framework 5中应用表值函数进行Linq查询

时间:2023-01-29 02:59:24

Entity Framework 5引入了表值函数(Table-Valued Functions TVFs)。表值函数的返回类型是一个Table类型,可用在SQL查询语句中。最简单的表值函数,读取客户表的记录,参考如下代码:

CREATE FUNCTION  GetCustomers
return table
AS return ( SELECT * FROM Customer) ;
 

此外,表值函数还可以指定要返回的表的列名和函数参数,请参考下面的代码例子:

 
CREATE FUNCTION  GetCustomer(@customerNo nvarchar(50))

returns table 

AS

RETURN (  select * from  customer where customerNo=@customerNo );

Entity Framework 5的Target是.NET 4.5,所以只有选择Visual Studio 2012才可以编译代码。

打开SQL Server Management Studio,运行下面的SQL表值函数:

CREATE FUNCTION [dbo].[GetStudentGradesForCourse]
(@CourseID INT)
RETURNS TABLE
RETURN
SELECT [EnrollmentID],
[CourseID],
[StudentID],
[Grade]
FROM [dbo].[StudentGrade]
WHERE CourseID = @CourseID

启动Visual Studio 2012,增加一个新项目,添加ADO.NET Entity Data Model。在选择模型内容对话框中,选择从数据库中产生,点击下一步,创建一个新的数据库连接。

在选择数据库对象窗口中,选择存储过程和函数节点,选取它下面的子节点GetStudentGradesForCourse函数,点击完成。

默认的,存储过程和函数的返回值会自动生成一个新复合类型,但是,我们需要的是让它返回一个StudentGrade对象,如上面的函数脚本所表达的。为达到此目的,在模型浏览器窗口中,选择导入的函数,双击GetStudentGradesForCourse函数,在编辑导入的函数对话框中,选择实体,然后选择StudentGrade类型。

在.NET代码中,请参考下面的Linq查询,它会调用表值函数,然后投影到一个新的匿名类型中,代码如下所示

using (var context = new SchoolEntities())
{
var CourseID = 4022;
var Grade = 3.5M; // Return all the best students in the Microeconomics class.
var students = from s in context.GetStudentGradesForCourse(CourseID)
where s.Grade >= Grade
select new
{
s.Person,
s.Course.Title
}; foreach (var result in students)
{
Console.WriteLine(
"Couse: {0}, Student: {1} {2}",
result.Title,
result.Person.FirstName,
result.Person.LastName);
}
}

Entity Framework中,需要手动拖动object(table,function,stored procedure)到实体设计器中,这样会有些不方便。如果想一次性把所选择的object都添加的实体设计器中,可以参考如下的方法。

应用工具 Huagati DBML/EDMX,它可以批量的添加数据库中的表,视图,或是存储过程和函数。

Entity Framework 5中应用表值函数进行Linq查询

官方的通知里面提到,此产品在今年底(2013.12.31)将停止开发(discontinue)。微软的构建的生态系统既垄断了框架开发的内容,还占据了开发工具领域,第三方的小工具生存的机率是很不容易。

除了微软自己的实体设计器,还有些第三方的实体设计工具,在这里做一个简单介绍。

Devart 的 Entity Designer,地址是 http://www.devart.com/entitydeveloper/,主要特性是支持模型优先和数据库优先的二种开发模式,而且支持框架NHibernate,ADO.NET Entity Framework,LinqConnect,Linq to SQL。

Solution Design的LLBL Gen Pro,地址是http://www.llblgen.com 

3.x的版本才引入的多框架支持,对其它的框架支持可能仅仅是个卖点,它自身框架的(LLBL Gen Pro Framework)已经非常成熟稳定。

LLBL Gen是一个支持多框架的实体设计工具,如NHibernate,Entity Framework,LLBL Gen Pro Framework。

Entity Framework 5中应用表值函数进行Linq查询的更多相关文章

  1. 在Entity Framework 7中进行数据迁移

    (此文章同时发表在本人微信公众号“dotNET每日精华文章”,欢迎右边二维码来关注.) 题记:虽然EF7重新设计了Entity Framework,不过也还是能够支持数据迁移的. Entity Fra ...

  2. 浅析Entity Framework Core中的并发处理

    前言 Entity Framework Core 2.0更新也已经有一段时间了,园子里也有不少的文章.. 本文主要是浅析一下Entity Framework Core的并发处理方式. 1.常见的并发处 ...

  3. Entity Framework 6 中如何获取 EntityTypeConfiguration 的 Edm 信息?(一)

    1. 案例1 - 类型和表之间的EF代码优先映射 从EF6.1开始,有一种更简单的方法可以做到这一点.有关 详细信息,请参阅我的新EF6.1类型和表格之间的映射. 直接贴代码了 从EF6.1开始,有一 ...

  4. 浅析Entity Framework Core2.0的日志记录与动态查询条件

    前言 Entity Framework Core 2.0更新也已经有一段时间了,园子里也有不少的文章.. 本文主要是浅析一下Entity Framework Core2.0的日志记录与动态查询条件 去 ...

  5. 使用Entity Framework Core需要注意的一个全表查询问题

    .NET Core 迁移工作如火如荼,今天在使用 Entity Frameowork Core(又名EF Core)时写了下面这样的 LINQ 查询表达式: .Where(u => u.Id = ...

  6. sqlserver中的表值函数和标量值函数

    顾名思义:表值函数返回的是表,而标量值函数可以返回基类型 一.表值函数 用户定义表值函数返回 table 数据类型.对于内联表值函数,没有函数主体:表是单个 SELECT 语句的结果集. 以下示例创建 ...

  7. Entity Framework 5中遇到的 mysql tinyint(1) 转换为 bool 的问题 (我用的是VS2013中的EF5版本)

    数据有一个字段,用的是 tinyint 长度是1  默认值为0 , 当用vs2013中的 EF5来生成 实体模型之后,看到这个列被标识为 bool 类型   Mysql官方参考文档关于布尔类型的说明: ...

  8. SQL Server中使用表值函数

    函数有很多限制,不能使用动态语句,不能使用临时表等等...细看一下,直接写语句就行了,不用动态语句 insert into @re select id,parid,@I from videoclass ...

  9. 如何处理Entity Framework / Entity Framework Core中的DbUpdateConcurrencyException异常(转载)

    1. Concurrency的作用 场景有个修改用户的页面功能,我们有一条数据User, ID是1的这个User的年龄是20, 性别是female(数据库中的原始数据)正确的该User的年龄是25, ...

随机推荐

  1. js 添加事件 attachEvent 和 addEventListener 的用法

    一般我们在JS中添加事件,是这样子的 ? 1 obj.onclick=method 这种绑定事件的方式,兼容主流浏览器,但如果一个元素上添加多次同一事件呢? ? 1 2 3 obj.onclick=m ...

  2. java io流之字节流

    字节流 字节流主要是操作byte类型数据,以byte数组为准,主要操作类就是OutputStream.InputStream 字节输出流:OutputStream OutputStream是整个IO包 ...

  3. 传智播客JavaWeb day06-jstl

    一.jsp标签(sun公司提供的) 二.EL表达式 三.jstl (javaserver pages standard tag library) 1.为什么要有jstl jsp标签太弱,el表达式功能 ...

  4. Git教程之工作区和暂存区(5)

    工作区(Working Directory) 就是你在电脑里能看到的目录,比如我的learngit文件夹就是一个工作区:

  5. JavaScript备忘录-闭包

    var arr = new Array(); function Person() { for (var i = 0; i < 10; i++) { //要记住,这个属性函数申明,只有立即执行才会 ...

  6. strcmp&lpar;&rpar; Anyone&quest;

    uva11732:http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_prob ...

  7. I&sol;O概述和审查操作

    I/O流量可表示非常多不同种类的输入源和输出目的地.它包含一个简单的字节流,基本数据(int.boolean.double等待),本地化字符,和对象.仅是简单地传递数据,另一些流能够操作和转换数据 不 ...

  8. def语句常见错误

    自觉不才,使用def语句时容易出现以下错误, 参考: 习题—25 http://www.2cto.com/shouce/Pythonbbf/ex25.html def add(): print &qu ...

  9. java中四种修饰符&lpar;private、default、protected、public&rpar;的访问权限

    权限如下: no. 范围 private default protected public 1 同一包下的同一个类 √ √ √ √ 2 同一包下的不同类 × √ √ √ 3 不同包下的子类 × × √ ...

  10. ArcGis 制图——地图图框整饰的插件式实现(一)C&num;

    如有插件定制需求或技术交流,欢迎联系QQ 975601416 写完了自己瞅了一眼都不想看,希望有需要的你能看懂. 先摆一张效果图: 下面进入主题,本篇先讲一下地图布局中的对象,正文中会对一些关键词用英 ...