首页 > 学院 > 开发设计 > 正文

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

2019-11-17 02:17:30
字体:
来源:转载
供稿:网友

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

Day3

第三天我们将学习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”。

clip_image001

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 并点击安装。

clip_image003

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>