在探讨系统重构的代码结构组织之前,先初步考虑框架与数据库的交互,在.net平台上数据访问方案有人总结为三类:DataSet、ADO.net 2.0、ORM组件。我只熟悉ADO.NET方式,众多的企业特性(如连接池、缓存等)均自行写代码实现,在此次重构时,我当然可以直接将原来的数据访问方案直接搬过来在Model中实现与数据层的交互,但既然考虑重构,为何不尝试一下新的ORM呢,在起初我考虑HNibernate框架的,但我在2008年的一个全国应用范围的项目中见过开发团队用Entity Framework作为数据层访问方案,一直对此方案比较好奇,所以这里采用Entity Framework 6.0.1

again, 对此有选择性障碍的人,停止寻找银弹吧,比如Entity Framework框架讨论很多的运行性能问题,我认为可用空间换时间的思路(比较粗暴的说法:硬件空间换响应时间。当然不是这样简单的概念,这里我个人喜欢这样概述此思路而已)来解决,不用钻牛角尖太深。

EF有三种方式(three ways)着手:Database First、Model First、Code First,通俗的话来说:

  • Database First:先构建数据库结构,然后通过逆向工程来自动创建数据模型和相关对象代码,最后通过这些对象来与数据库交互
  • Model First:先在VS工具中创建数据模型,然后自动生成相关对象代码及数据库,最后通过这些对象来与数据库交互
  • Code First:先在VS中创建数据对象类,EF自动转换成模型及数据库,最后通过这些对象来与数据库交互

通常分工明确的项目团队中,设计人员用ORM工具(比如我习惯用PowerDesigner)完成数据库结构的设计,然后交给开发人员进行逻辑代码的开发。 for me, 这部分工作已经完成了,整个后台管理平台的数据结构乖乖的列在数据库中了,看起来我可用Database First方式着手。

这里顺便想提一句Code First方式,这令我回想起早几年的技术销售(TS)的工作,这个角色的工作中涉及的POC要求一个快字,Code First简直就是为快而生的,用户POC需求拿到后,直接进入代码编写业务逻辑,不用花时间在数据层的处理上,最重要的是POC成功后,即使要将POC直接转化到生产环境也是可行的。

Code First方式简单的开发流程可概括如下:

  1. 直接在Model中创建代表业务实体(Entity)的类(class),以下是几个基本规则(更复杂的Entity定义规格可参阅这里)
    1. Entity(或者说数据表)的关键字默认规则:"ID" or "classsnameID"属性为关键字。当然DatabaseGenerated标签可允许自己定义关键字
    2. Entity间的一对多关联用泛型集合类型的navigation property来表示
    3. Entity类名默认是数据表名,Entity类属性默认是数据表字段名
    4. foreign key的默认定义规则:<navigation property name><primary key property name>
  2. 创建Database Context(这里除了创建数据库连接外,还将数据表与Entity关联起来)
    1. 用DbSet<T>将数据表与定义的Model类关联起来,且DbSet会完成常见的数据表CRUD操作
  3. 创建视图显示Entity对象

开发流程的核心基本就是如此,中间涉及的各种规则可参阅这里,包括数据库连接字符串规则、Entity关联规则、甚至你可以自定义规则

一句话小结三种方式的选择:Code First适合做演示系统,很多东西不用费时间考虑,Database First显然适合导入现有的数据结构,从头实施大型项目还是以模型先着手,完整的模型视图有利于理清各个对象间的关系。

确定了asp.net mvc + EF 后,接下来如何进行呢?对我来说,涉及的新技术好多哦,系统的学习是不可能的,我决定采取这样的方式进行:搜集asp.net mvc的最佳实践经验,以此为基础来展开本次重构,总体来讲从以下几个方面着手搜集

  • 代码结构的组织
  • 身份验证机制的新实现(针对我原系统而言)
  • 权限管理机制的新实现(针对我原系统而言)
  • 资源管理机制(一项具体业务,这里不详述其内容)

Microsoft 2013 新技术学习笔记 二的更多相关文章

  1. Microsoft 2013 新技术学习笔记 一

    有几年没有关注技术了,最近有点时间想把技术重新捡起来,借着重构手上的一个后台管理框架的机会将微软新的几种技术全部应用一下,从目的上来讲并没有希望能对涉及的技术有很深入的了解,所以这个系列的文章(篇幅不 ...

  2. Microsoft 2013 新技术学习笔记 三

    什么是代码结构的组织?asp.net MVC 5 默认创建出的几个目录的标准含义分别如下: Controllers目录存放MVC模式中的Controler Models目录存放MVC模式中的Model ...

  3. Microsoft 2013 新技术学习笔记 四

    在继续学习Model的实践经验之前,先思考一下Controller和View的实践原则在本次系统重构中的应用,我手上是一个后台管理系统(不是门户系统.不是具体业务系统),通俗点讲就是给企业的运维人员用 ...

  4. AJax 学习笔记二(onreadystatechange的作用)

    AJax 学习笔记二(onreadystatechange的作用) 当发送一个请求后,客户端无法确定什么时候会完成这个请求,所以需要用事件机制来捕获请求的状态XMLHttpRequest对象提供了on ...

  5. python3.4学习笔记(二十四) Python pycharm window安装redis MySQL-python相关方法

    python3.4学习笔记(二十四) Python pycharm window安装redis MySQL-python相关方法window安装redis,下载Redis的压缩包https://git ...

  6. kvm虚拟化学习笔记(二)之linux kvm虚拟机安装

    KVM虚拟化学习笔记系列文章列表----------------------------------------kvm虚拟化学习笔记(一)之kvm虚拟化环境安装http://koumm.blog.51 ...

  7. WPF的Binding学习笔记(二)

    原文: http://www.cnblogs.com/pasoraku/archive/2012/10/25/2738428.htmlWPF的Binding学习笔记(二) 上次学了点点Binding的 ...

  8. [Firefly引擎][学习笔记二][已完结]卡牌游戏开发模型的设计

    源地址:http://bbs.9miao.com/thread-44603-1-1.html 在此补充一下Socket的验证机制:socket登陆验证.会采用session会话超时的机制做心跳接口验证 ...

  9. JMX学习笔记(二)-Notification

    Notification通知,也可理解为消息,有通知,必然有发送通知的广播,JMX这里采用了一种订阅的方式,类似于观察者模式,注册一个观察者到广播里,当有通知时,广播通过调用观察者,逐一通知. 这里写 ...

随机推荐

  1. 团队项目——站立会议 DAY1

    团队项目--站立会议 DAY1        团队成员介绍(5人):张靖颜.何玥.钟灵毓秀.赵莹.王梓萱        今日(2016/5/6)为站立会议的第一天,一起对团队项目进行讨论,并对每个人的 ...

  2. [JS4] 最简单JS框架

    <html> <head> <title></title> <SCRIPT TYPE="text/JavaScript"> ...

  3. 比较任意两个JSON串是否相等(比较对象是否相等)JAVA版

    废话少说,直接入题. 在面向对象语言中,经常会比较两个对象是否相等,而比较的大多是实体类实例,也就是封装数据的那些类实例,或者是Map.List互相嵌套成的复杂数据结构. 比较对象是否相等,常见的思路 ...

  4. ThreadLocal线程范围内的共享变量

    模拟ThreadLocal类实现:线程范围内的共享变量,每个线程只能访问他自己的,不能访问别的线程. package com.ljq.test.thread; import java.util.Has ...

  5. paip.提升效率--数据绑定到table原理和流程Angular js jquery实现

    paip.提升效率--数据绑定到table原理和流程Angular js  jquery实现 html #--keyword 1 #---原理和流程 1 #----jq实现的代码 1 #-----An ...

  6. Effective STL中文版 译序

    <Effective STL中文版>译序 就像本书的前两本姊妹作(Effective C++.More Effective C++)一样,本书的侧重点仍然在于提升读者的经验,只不过这次将焦 ...

  7. javaweb学习总结(二十)——JavaBean总结

    一.什么是JavaBean JavaBean是一个遵循特定写法的Java类,它通常具有如下特点: 这个Java类必须具有一个无参的构造函数 属性必须私有化. 私有化的属性必须通过public类型的方法 ...

  8. window.history.pushState与ajax实现无刷新更新页面url

    ajax能无刷新更新数据,但是不能更新url HTML5的新API: window.history.pushState, window.history.replaceState 用户操作history ...

  9. 使用gulp进行React任务的构建

    如果你不熟悉gulp的操作,可以看下下面的教程: gulp学习笔记1 gulp学习笔记2 gulp学习笔记3 gulp学习笔记4 对于gulp在react中的构建,找了很多资料,看了很多文章,也根据文 ...

  10. 開啟apache的日誌功能,但是不記錄.js;.css;.jpg;.ico;.png等訪問記錄

    維護web伺服器最重要的就是要每天都關注網站的訪問日誌,但是每天面對幾百兆的日誌文件實在是非常頭大,所以可以從根源上給日誌減肥一下,讓日誌只記錄對自己有用的內容就變得非常重了. Nginx伺服器要修改 ...