什么是Entity Framework

Entity Framework是微软以 ADO.NET 为基础所发展出来的对象关系对应 (O/R Mapping) 解决方案。将数据存储从域对象自动映射到关系型数据库,让开发人员节不需要编写大量的数据访问代码,节省了数据库访问的代码时间,对数据库操作如同操作Object对象一样省事。

Entity Framework在使用当中有3中模式,分别是Code FirstModel First以及Database First

由于我最早接触的是Database First这种模式,所以首先我们就来了解一下Database First模式的基本用法。

创建一个数据库

Database First顾名思意就是首先需要一个存在的数据库,所以这里需要创建一个数据库。

这里我们还是以Product为例。

Product表包含以下字段。

创建Console Application

我们为了方便简单点,这里我们创建一个Console Application程序。

VS中选择创建一个Console Application程序。

创建ADO.NET Entity Data Model

这里我们选择ADO.NET Entity Data Model,命名为Product,后缀为.edmx文件。

点击Add按钮,弹出下面的向导框,选择Generate from database,也就是我们需要的Database First模式。

点击Next按钮,来到以下向导框中,选择我们之前创建的数据库,并为这个Entity Connection命名为ProductContext

继续点击Next按钮,来到以下向导框中,选择我们需要添加的表,并输入一个Model Namespace

点击Finish按钮,创建成功后我们可以看到自动安装了EntityFramwork的参考引用,还有我们创建的名为Product.edmx的文件。

双击打开Product.edmx文件,可以看到我们选择的Product表也加载映射到了文件当中。

基本的CRUD操作

下面我们开始在控制台程序里对Product表数据进行简单CRUD操作,打开Program.cs文件,在Main方法里编写CRUD代码,这里我们插入两条数据Product NameProduct AProduct B,修改Product NameProduct A的记录,删除Product NameProduct B的记录。

代码如下:

        static void Main(string[] args)
{
using (var productContext = new ProductContext())
{
// Create
Console.WriteLine("创建两个Product. Product A and Product B.");
var productList = new List<Product>{
new Product
{
ProductName = "Product A",
Price = ,
Count = ,
Description = "Description A"
},
new Product
{
ProductName = "Product B",
Price = ,
Count = ,
Description = "Description B"
}
};
productContext.Product.AddRange(productList);
productContext.SaveChanges();
Console.WriteLine("创建成功.");
// Display
Console.WriteLine("显示当前所有Product.");
var products = productContext.Product.ToList();
foreach (var item in products)
{
Console.WriteLine("{0} {1} {2} {3} {4}", item.ProductID, item.ProductName, item.Price, item.Count, item.Description);
}
Console.WriteLine(); // Update
Console.WriteLine("修改Product A为Product AAA.");
var productUpdate = productContext.Product.Where(p => p.ProductName == "Product A").FirstOrDefault();
if (productUpdate != null)
{
productUpdate.ProductName = "Product AAA";
productContext.Entry(productUpdate).State = EntityState.Modified;
productContext.SaveChanges();
Console.WriteLine("修改成功.");
} // Display
Console.WriteLine("显示当前所有Product.");
products = productContext.Product.ToList();
foreach (var item in products)
{
Console.WriteLine("{0} {1} {2} {3} {4}", item.ProductID, item.ProductName, item.Price, item.Count, item.Description);
}
Console.WriteLine(); // Delete
Console.WriteLine("删除Product B.");
var productDelete = productContext.Product.Where(p => p.ProductName == "Product B").FirstOrDefault();
if (productContext != null)
{
productContext.Product.Remove(productDelete);
productContext.SaveChanges();
Console.WriteLine("删除成功.");
} // Display
Console.WriteLine("显示当前所有Product.");
products = productContext.Product.ToList();
foreach (var item in products)
{
Console.WriteLine("{0} {1} {2} {3} {4}", item.ProductID, item.ProductName, item.Price, item.Count, item.Description);
} Console.ReadKey();
}
}

运行代码,效果如下图。

数据库表变化、视图、存储过程等基本操作

我们在项目开发阶段,有时候会遇到一些表后期需要加一些字段,那么我们来看看如果更新这些表的变化。

这里我们假如需要知道每个产品归属一个公司,那么我们需要新增一个公司Company表,并且在Product表新增一个CompanyID的字段,与Company表形成对应。

新增了一个Company表并且修改了Product表,接下来我们要更新我们的Entity Data Model。打开Product.edmx文件,右键单击选择Update Model from Database

在弹出的向导框中,分别选择Add我们新建的Company表和Refresh我们修改的Product表。

点击Finish按钮。我们看到新建的Company表和修改的Product表都更新到了Model当中。

当我们在实际项目当中,有时候在做复杂的处理,比如需要更新多个表的内容,或者需要多个表联合查询的数据,我们可能更多的需要视图和存储过程来完成,那么这里我们看看如何加载视图和存储过程以及怎么调用它们。

首先我们简单的建立一个视图和一个存储过程。

CREATE VIEW [dbo].[vProductAndCompany]
AS
SELECT dbo.Product.ProductID, dbo.Product.ProductName, dbo.Product.Count, dbo.Product.Price, dbo.Product.Description, dbo.Company.CompanyName
FROM dbo.Product LEFT OUTER JOIN
dbo.Company ON dbo.Product.CompanyID = dbo.Company.CompanyID GO
CREATE  PROCEDURE [dbo].[spSaveOrUpdateProduct](
@ProductID int,
@ProductName nvarchar(),
@Price decimal(,),
@Count int,
@Description nvarchar(max),
@CompanyID int
)
AS
BEGIN
declare @CurrentProductID int
if exists(select ProductID from Product where ProductID=@ProductID)
begin
update Product set
ProductName=@ProductName,
Price=@Price,
[Count]=@Count,
[Description]=@Description,
CompanyID=@CompanyID
where ProductID=@ProductID set @CurrentProductID=@ProductID end
else
begin
insert into Product(ProductName,Price,[Count],[Description],CompanyID)
values(@ProductName,@Price,@Count,@Description,@CompanyID) set @CurrentProductID=cast(SCOPE_IDENTITY() as int);
end select @CurrentProductID as [RowCount]
END

接下来我们同样打开Product.edmx文件,右键单击选择Update Model from Database。在向导框中选择我们新建的视图和存储过程。

点击Finish按钮,我们可以看到新建的视图vProductAndCompany也更新到了Model中。

那么如何看到新增的存储过程到哪里了,我们依旧打开Product.edmx文件,右键单击选择Model Browser

我们看到右侧的Model BrowserFunction Imports下就是我们新增的存储过程,双击打开图中可以编辑它的名称以及返回值类型等。

接下来我们就可以来操作视图以及存储过程了。

首先,先准备一些测试数据,分别向Product表和Company表中插入一些数据。

 -- Company
insert into Company(CompanyName) values('Company A')
insert into Company(CompanyName) values('Company B')
insert into Company(CompanyName) values('Company C') -- Product
insert into Product(ProductName,Price,[Count],[Description],CompanyID) values('Product A',,,'Description A',)
insert into Product(ProductName,Price,[Count],[Description],CompanyID) values('Product B',,,'Description B',)
insert into Product(ProductName,Price,[Count],[Description],CompanyID) values('Product C',,,'Description C',)
insert into Product(ProductName,Price,[Count],[Description],CompanyID) values('Product D',,,'Description D',)
insert into Product(ProductName,Price,[Count],[Description],CompanyID) values('Product E',,,'Description E',)

接着,我们代码实现调用存储新增一条Product数据,并且调用视图显示全部视图数据。

                Console.WriteLine("显示当前所有Product.");
var products = productContext.vProductAndCompany.ToList();
foreach (var item in products)
{
Console.WriteLine("{0} {1} {2} {3} {4} {5}", item.ProductID, item.ProductName, item.Price, item.Count, item.Description, item.CompanyName);
} Console.WriteLine("新增一个Product.名为Product F");
var newProduct = new Product
{
ProductID = ,
ProductName = "Product F",
Price = ,
Count = ,
Description = "Description F",
CompanyID =
};
var result = productContext.spSaveOrUpdateProduct(newProduct.ProductID, newProduct.ProductName, newProduct.Price, newProduct.Count, newProduct.Description, newProduct.CompanyID);
foreach (int returnValue in result)
{
if (returnValue > )
{
Console.WriteLine("新增成功.");
}
} Console.WriteLine("显示当前所有Product.");
products = productContext.vProductAndCompany.ToList();
foreach (var item in products)
{
Console.WriteLine("{0} {1} {2} {3} {4} {5}", item.ProductID, item.ProductName, item.Price, item.Count, item.Description, item.CompanyName);
}
Console.ReadKey();

运行程序,结果如下。

另外,除了通过以上方式来对数据库数据操作之外,当然也可以直接用SQL命令。

                var strQuery = "select ProductID,ProductName,Count,Price,Description,CompanyID from Product";
var products = productContext.Database.SqlQuery<Product>(strQuery).ToList();
Console.WriteLine("显示当前Product集合数据.");
foreach (var item in products)
{
Console.WriteLine("{0} {1} {2} {3} {4} {5}", item.ProductID, item.ProductName, item.Price, item.Count, item.Description, item.CompanyID);
}
Console.WriteLine(); Console.WriteLine("更新Product F为Product FFF.");
string newProductName = "Product FFF";
var strCommand = string.Format("update Product set ProductName='{0}' where ProductID=6", newProductName);
var result = productContext.Database.ExecuteSqlCommand(strCommand);
Console.WriteLine("更新成功.");
Console.WriteLine(); products = productContext.Database.SqlQuery<Product>(strQuery).ToList();
Console.WriteLine("显示更新后的Product集合数据.");
foreach (var item in products)
{
Console.WriteLine("{0} {1} {2} {3} {4} {5}", item.ProductID, item.ProductName, item.Price, item.Count, item.Description, item.CompanyID);
} Console.ReadKey();

运行程序,结果如下。

这里我们简单的列举一下查询和更新,其他操作类似,这里就不一一介绍了。

好了,本篇就先到此,希望对你有所帮助,谢谢!

Entity Framework — ( Database First )的更多相关文章

  1. 如何正确地使用Entity Framework Database First

    毕设依旧在不紧不慢地以每天解决一个问题的进度进行中.今天遇到的问题就是在建立数据模型时遇到的.因为项目是基于数据库构建的,所以理所应当地采用DB First来构造实体类和DbContext类.于是想也 ...

  2. mvc+entity framework database first,生成的model每次更新一个表会更新所有的model

    在使用Entity Framework 的Database frist或model first时,直接加attribute到modle类上是太现实也不合理的,因为model类是自动生成的,重新生成后会 ...

  3. asp.net mvc5 step by step(三)—— Entity Framework Database First

    一.先建数据库. 打开,SQL Server Management 新建数据库Employee 并新建表 /****** Object: Table [dbo].[t_Employee] Script ...

  4. Entity Framework 之Database first(数据库优先)&Model First(模型优先)

    一.什么是Entity Framework 1.1 实体框架(EF)是一个对象关系映射器,使.NET开发人员使用特定于域的对象与关系数据.它消除了需要开发人员通常需要编写的大部分数据访问代码.简化了原 ...

  5. C# ORM—Entity Framework 之Database first(数据库优先)&Model First(模型优先)(一)

    一.什么是Entity Framework 1.1 实体框架(EF)是一个对象关系映射器,使.NET开发人员使用特定于域的对象与关系数据.它消除了需要开发人员通常需要编写的大部分数据访问代码.简化了原 ...

  6. ADO.NET Entity Framework CodeFirst 如何输出日志(EF 5.0)

    ADO.NET Entity Framework CodeFirst 如何输出日志(EF4.3) 用的EFProviderWrappers ,这个组件好久没有更新了,对于SQL执行日志的解决方案的需求 ...

  7. Solve: Your project references the latest version of Entity Framework (for MySQL) in Visual Studio 2013

    The error message while trying to create a ADO.net Entity Data Model ( Entity Framework 6 ) for MySq ...

  8. [转]Entity Framework and slow bulk INSERTs

    本文转自:https://weblog.west-wind.com/posts/2013/Dec/22/Entity-Framework-and-slow-bulk-INSERTs I’ve been ...

  9. .NET Core开发日志——Entity Framework与PostgreSQL

    Entity Framework在.NET Core中被命名为Entity Framework Core.虽然一般会用于对SQL Server数据库进行数据操作,但其实它还支持其它数据库,这里就以Po ...

随机推荐

  1. Android注解学习(1)

    对于注解这个概念刚开始不是很理解,翻阅了其他人博客,参考实现的例子开始理解与运用.以前刚开始的写android项目时,一般找定义控件并初始化控件都是调用findviewbyId,然而当一个布局页面(类 ...

  2. WEB前端性能优化之二——css优化

    1.把样式表置于顶部 现把样式表放到文档的< head />内部似乎会加快页面的下载速度.这是因为把样式表放到< head />内会使页面有步骤的加载显示.HTML规范清 楚指 ...

  3. java-9 异常处理

    1.异常处理的基础知识 异常是程序中的一些错误,但并不是所有的错误都是异常,并且错误有时候是可以避免的. 比如说,你的代码少了一个分号,那么运行出来结果是提示是错误 java.lang.Error:如 ...

  4. excel表格的特殊需求引发的Java思考

    前言: 前些天遇到了这样的一个需求,将下图: 将表格中货号-前面部分一致的行合成一行,并且将第二行,第三行的价格添加到第一行中为价格二,价格三.如图: 接到这样的需求,我的第一感觉是直接手动合并(暗暗 ...

  5. [Hadoop] - TaskTracker源码分析

    在Hadoop1.x版本中,MapReduce采用master/salve架构,TaskTracker就是这个架构中的slave部分.TaskTracker以服务组件的形式存在,负责任务的执行和任务状 ...

  6. 2011 Multi-University Training Contest 1 - Host by HNU

    A.A + B problem(待填坑) B.Cat VS Dog(二分图匹配) 喜欢cat和喜欢dog的人构成了二分图,如果两个人有冲突则连一条边,则问题转化为二分图最大点独立集问题.ans=n-最 ...

  7. BZOJ USACO 银组 水题集锦

    最近刷银组刷得好欢快,好像都是水题,在这里吧他们都记录一下吧(都是水题大家一定是道道都虐的把= =)几道比较神奇的题到时再列出来单独讲一下吧= =(其实我会说是BZOJ蹦了无聊再来写的么 = =) [ ...

  8. java调用控制台命令

    String shell = "ping www.baidu.com";//需要执行的命令 BufferedReader br = null;try { Process p = R ...

  9. angular : direative :comunication 指令之间的通讯

    在网络上可以找到多种指令之间的通讯 · $on,$emit,$boardcast (向上或向下冒泡) · 指令return的required (^)向上一个scope通讯,前提要先给scope一个na ...

  10. USB重定向

    第一期中,我们一起简要的看了下传统PC和桌面云下USB重定向和USB设备重定向方式的差异,了解了桌面云下外设兼容性问题来源的根源-USB设备本身驱动不规范/不支持, 或者虚拟机驱动实现上与USB设备对 ...