打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
MVC-05 Model(1)
MVC-05 Model(1)

在开发应用程序的过程中,经常需要处理许多大大小小的数据,例如,SQL Server数据库存取、连接AD(Active Directory)数据库进行验证、调用外部Web Service取得数据等。除了访问数据外,也经常需要对数据做成格式验证、逻辑验证等等。

一、Model的责任

在ASP.NET MVC中,Model负责所有与“数据”有关的任务。所以,不管是Controller或是View,都会参考到Model里定义的所有数据类型,或是用到Model里定义的一些数据操作方法,例如,新增、删除、更改、查询等。

在Model里的程序,由于“只能”跟数据域商业逻辑有关,所以就不负责处理所有与数据处理无关的事,或是用来控制网站的运行流程等,而是专注于如何有效率地提供数据访问机制、交易环境、数据格式验证、商业逻辑验证等工作。

由于Model的独立性非常高,如果你在一个Visual Studio方案中,有多个要开发的项目,比如有时我们会将Model独立成一个项目,让Model项目共享于不同的项目之间。

二、开发Model的基本观念

当采用ASP.NET MVC框架时,虽然在Model层的开发技术繁多,而且ASP.NET MVC也保留了许多弹性,让各个不同的数据访问技术都能跟ASP.NET MVC集成。不过,若要充分发挥ASP.NET MVC快速开发的优势,还是建议读者在Model层采用ORM信息访问技术来开发,例如,LINQ to SQL、Entity Framework、NHibernate、Telerik OpenAccess ORM等。

1.何谓ORM

ORM的全名是Object Relational Mapping,中文翻译为“对象关系映射”,是一种编程技术,用于实现面向对象程序语言里,不同类型系统之间的数据转换。通常在实务的应用上,大多数情况都会应用在数据库与面向对象程序自检的类型转换,例如,SQL Server中的关系型数据与.NET类型对象之间的转换等。

换句话说,ORM是将结构化的关系型数据,映射成面向对象模型。如果以Entity Framework来说,就是试图将关系数据库的各种数据转换成.NET原生对象,或是将.NET模型类对象数据转换成关系型数据。

使用ORM开发技术跟常规使用ADO.NET开发技术最大的差异,就在于操作“数据”的方便性与弹性。以往在使用ADO.NET开发数据访问程序时,开发人员通常必须先了解完整的数据库操作方法,才能顺利地从数据库取得数据,或是将对象的数据保存到数据库中。例如,要编写操作SQL Server数据库中的数据,就必须先学习T-SQL的使用方式;若要操作Oracle数据库中的数据,也必须先学习Oracle的SQL查询语法。学会之后还要学习各式ADO.NET的标准API,才能知道如何正确地与数据库交互,明白是要进行查询数据、更新数据、新增数据还是删除数据等。不同的数据库,在设计逻辑与SQL语法上都会有些小差异,而导致开发数据访问的程序代码缺乏效率。如此一来,也有违“关注点分离”的特性,若是套用“关注点分离”特性,照理说在开发.NET应用程序时,应该专注在对象的操作上,而非数据库数据的处理,当采用ORM开发技术后,便可以帮助我们达到这个目的。

Entity Framwork是建构在ADO.NET数据提供者模型之上,也就是说,只要.NET运行环境能够使用ADO.NET连接数据库,Enity Framework便能顺利支持,在.NET运行环境下默认已经支持SQL Server 2005以上版本,如果要支持其他如Oracle、MySQL、SQLite、PostgreSQL等各式各样的关系数据库基本上也是没问题的,只要操作出相对应的Entity Framework数据提供者即可。

2.数据库开发模式

采用Entity Framework或其他ORM开发极速,有时还可区分三种不同的开发模式,分别是数据库优先开发模式(Database First Development)、模型优先开发模式(Model First Development)、程序代码优先开发模式(Code First Development)。

(1)数据库优先开发模式

顾名思义,数据库优先开发模式就是针对数据库进行设计,以数据库里定义的数据结构(Schema)为主。当应用程序在卡法的时候,必须依据数据库的结构设计来进行开发,使用的ORM框架必须能够依据数据库结构设计生成相应的对象模型,才能提供给应用程序来使用。

(2)模型优先开发模式

模型优先开发模式是指在ORM架构中创建对象模型,让应用程序能够依据这些对象模型进行开发。需要实际访问数据库时,只要通过Entity Framework数据提供者的协助,动态生成相应的SQL语法,即可创建出完整的数据库。

一般来说,支持模型优先开发模式的ORM框架,都会有相对应的程序代码生成技术,在模型被创建的同时自动生成相对应的程序代码。以Entity Framework为例,在搭配Visual Studio的帮助下,即可通过Entity Framework设计工具,帮你创建对象模型,只要保存后,就会自动生成相关程序代码。

(3)程序代码优先开发模式

程序代码优先开发模式是一种非常新颖的开发模式,也就是让开发人员直接依据需求,编写类别与属性(程序代码),而这些撰写的类别与属性正是定义出应用程序所需的数据模型,并且通过ORM框架的管理,便可让这些POCO类型,转换成实体模型(Entity Model)。

直到程序开始运行后,通过ORM框架,就可以自动依据这些类别,定义创建数据库、表格、字段与其他数据结构(Schema)。这样开发人员便可以完全不需要接触数据库这一端的各种管理工作(如创建表格字段、设计数据表、设计数据表关联等),也不用学习各式数据库的使用差异(如SQL Server、Oracle、MySQL、SQLite等),省去这些工作之后,开发人员更能专注在应用程序的需求开发,而不会因为不熟悉数据库操作而束手束脚。

三、LocalDB介绍

微软最新推出的SQL Server 2012 Express LocalDB,是一种SQL Server Express的运行模式,特别适合在开发环境使用,也内建在Visual Studio 2012之中。

1.LocalDB的运作方式

在安装好SQL Server 2012 Express LocalDB之后,默认会有个实例名,为v11.0。

2.如何连接LocalDB实例

(1)使用Management Studio连接LocalDB

在连接对话框中输入正确服务器名称,(localdb)\v11.0。只有新版的SQL Server 2012 Management Studio才能识别这组新的服务器名称。

(2)通过.NET程序连接LocalDB实例

连接字符串如下。

3.管理LocalDB自动实例

4.管理LocalDB具名实例

四、使用Code First创建数据模型

ASP.NET MVC4与当前最新版的Entity Framework 5同时上市,尤其强化了程序代码优先开发模式的支持。

1.创建数据模型

(1)声明主键

要想在Entity Framework声明主键,最简单的方式就是不要声明,直接把属性名称设置为Id或是苏醒名称中共有“Id”也可以,并将该属性指派为int类型即可。EF Code First会自动识别出这个字段就是表格里的主键,并且会加上自动编号的识别规格设置。

(2)声明必填字段

(3)声明允许NULL字段

(4)声明字段长度

(5)声明字段默认值

(6)声明特定属性不是数据中的字段

2.创建数据上下文类

3.设计模型之间的关联性

4.启用延迟装入特性

五、使用Code First数据库迁移

六、使用ViewModel数据视图模型

七、扩充数据模型

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
ADO.NET Entity Framework 学习 1 - VS2010学习 - IC窗口
灵动思绪EF(Entity FrameWork)
EF框架
[ASP.NET MVC 小牛之路]06 - 使用 Entity Framework Code First
ADO.NET Entity Framework
.NET(C 或者ASP.NET)的框架(一)
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服