MVC (三)——ASP.Net MVC 数据处理

王朝学院·作者佚名  2016-05-20
窄屏简体版  字體: |||超大  

七天学会asp.net MVC (三)——ASP.Net MVC 数据处理第三天我们将学习Asp.Net中数据处理功能,了解数据访问层,EF,以及EF中常用的代码实现方式,创建数据访问层和数据入口,处理Post数据,以及数据验证等功能。系列文章七天学会ASP.NET MVC (一)——深入理解ASP.NET MVC

七天学会ASP.NET MVC (二)——ASP.NET MVC 数据传递

七天学会ASP.NET MVC (三)——ASP.Net MVC 数据处理

七天学会ASP.NET MVC (四)——用户授权认证问题

七天学会ASP.NET MVC (五)——Layout页面使用和用户角色管理

七天学会ASP.NET MVC (六)——线程问题、异常处理、自定义URL

目录:数据访问层

实体框架(EF)简述

什么是代码优先的方法?

实验8——在项目中添加数据访问层

关于实验8

实验9——创建数据输入屏幕

实验10——获取服务端或控制器端传递的数据。

实验11——重置及取消按钮

实验12——保存数据。库记录并更新表格

实验13——添加服务器端验证

实验14——自定义服务器端验证

结论

数据访问层在实际开发中,如果一个项目不包含任何数据库,那么这个项目是不完整的,我们在一二节实例中未涉及数据库,在本节开始,实验8中讲解一个关于数据库和数据库层的实例。

本节将使用SQL Server和EF(Entity Framework)创建相关的数据库及数据库访问层。

简述实体框架(EF)EF是一种ORM工具,ORM表示对象关联映射。

在RDMS中,对象称为表格和列对象,而在.net中(面向对象)称为类,对象以及属性。

任何数据驱动的应用实现的方式有两种:

1. 通过代码与数据库关联(称为数据访问层或数据逻辑层)

2. 通过编写代码将数据库数据映射到面向对象数据,或反向操作。

ORM是一种能够自动完成这两种方式的工具。EF是微软的ORM工具。

什么是代码优先的方法?EF提供了三种方式来实现项目:

l 数据库优先方法——创建数据库,包含表,列以及表之间的关系等,EF会根据数据库生成相应的Model类(业务实体)及数据访问层代码。

l 模型优先方法——模型优先指模型类及模型之间的关系是由Model设计人员在VS中手动生成和设计的,EF将模型生成数据访问层和数据库。

l 代码优先方法——代码优先指手动创建POCO类。这些类之间的关系使用代码定义。当应用程序首次执行时,EF将在数据库服务器中自动生成数据访问层以及相应的数据库。

什么是POCO类?POCO即Plain Old CLR对象,POCO类就是已经创建的简单.Net类。在上两节的实例中,Employee类就是一个简单的POCO类。

实验8——添加数据访问层1. 创建数据库

连接SQL SERVER ,创建数据库 “SalesERPDB”。

2. 创建连接字符串(ConnectionString)

打开Web.Config 文件,在< Configuration >标签内添加以下代码:

1: <connectionStrings>

2: <add connectionString="Data Source=(local);Initial Catalog=SalesERPDB;Integrated Security=True"

3: name="SalesERPDAL"

4: PRoviderName="System.Data.SqlClient"/>

5: </connectionStrings>

3. 添加EF引用

右击项目->管理Nuget 包。选择Entity Framework 并点击安装。

4. 创建数据访问层

在根目录下,新建文件夹”Data access Layer“,并在Data Access Layer文件夹中新建类” SalesERPDAL “在类文件顶部添加 Using System.Data.Entity代码。继承DbContext类 1: public class SalesERPDAL: DbContext

2: {

3: }

5. 创建Employee类的主键

打开Employee类,输入using语句

1: using System.ComponentModel.DataAnnotations;

添加Employee的属性,并使用Key 关键字标识主键。

public class Employee{ [Key] public int EmployeeId { get; set; } public string FirstName { get; set; } public string LastName { get; set; } public int Salary { get; set; }}

6. 定义映射关系

在SalesERPDAL类文件输入using语句。

1: using Webapplication1.Models;

在 SalesERPDAL 类中重写 OnModelCreating方法,代码如下:

1: protected override void OnModelCreating(DbModelBuilder modelBuilder)

2: {

3: modelBuilder.Entity<employee>().ToTable("TblEmployee");

4: base.OnModelCreating(modelBuilder);

5: }

6: </employee>

注意:上述代码中提到“TblEmployee”是表名称,是运行时自动生成的。

7. 在数据库中添加新属性Employee

在 SalesERPDAL 类中添加新属性 Employee。

1: public DbSet<employee> Employees{get;set;}

2: </employee>

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航