数据层全栈式编程架构

CRUD全栈式编程架构之数据层的设计

CodeFirst

  一直以来我们写应用的时候首先都是创建数据库
  终于在orm支持codefirst之后,我们可以先建模。
  通过模型去创建数据库,并且基于codefirst可以实现方便的
  实现数据库迁移的工作.使用codefirst有以下几个技巧,
  以EntityFramework为例,结合我这个设计做了以下改进

1.模型的识别

  建立一个基类命名Entity,里面只有一个long类型的id字段。
  所有需要映射到数据库的模型都继承自Entity,

+

2.模型的映射

  选用fluntapi作为配置(可以保持模型类的整洁,并且和具体orm无关)
      新建一个配置基类继承自EntityTypeConfiguration,并且添加泛型约束,
      在构造函数中配置表名(和类名一致),和id作为主键,并且设置成由程序生成。
      如果是一般单表的话,配合System.ComponentModel.DataAnnotations下的特性
      即可完成数据库字段长度等等限制

+

3.模型的生成

  重写DbContext的OnModelCreating方法,反射程序集所有需要映射的类型,
  然后,查找对应配置,如果没有则构造出配置基类,即可完成模型的创建,
  ef默认会在第一次访问的时候去创建或者校验模型,
  模型的配置缓存在全局静态数据中。如果对应模型类有

+

Repository

  关于Repository的文章很多,这里就不重复描述了。
  我这里都是采用的接口编程,全部是采用构造函数来注入。
  我这里需要为每个类型的CurdService注入一个默认Repository实现。

+

其他一些技术

UnitOfWork(工作单元)

  网上文章也很多,简单来说,把若干个数据库操作放在一起作为事务提交
  得益于ef的设计,ef使用dbcontext.savechanges()方法等价于unitofwork.commit()方法
  这部分的设计主要借鉴NLayerApp.
  如果没有ef我建议是把每一个增删改类型的sql命令做成委托,然后左后commit的时候
  使用事务提交。代码如下

+

Specification(规约)

  同样网上的文章也很多,我这里只是把他作为查询实体来使用.
  如果使用传统ado.net的方式,直接传表达式到Repository中的话
  将导致解析表达式特别复杂,而用Specification的话,相当于查询
  语句中的where部分由它来接管,这样解耦和Repository和具体orm的依赖
  这部分的设计主要借鉴NLayerApp

多排序

  在分页中我们经常遇到多查询的情况,核心就是构造表达式,等同于构造
  sql语句中orderby的部分,同时它也支持内存中的多排序
  这部分设计主要借鉴Apworks中多排序的设计

+

Ps:

  比较零碎,如果有什么问题可以在下面给我留言。
  其中模型创建代码中有一个_context.这个属于下个系列内容。
      主要用来搭配模块化做业务垂直分库用.
  重点是看设计思路,代码只是给一个演示,一般照搬是编译不过的.
      文章系列的结尾会放出一个完整的设计代码和一个简单的示例.

分类: CRUD全栈式编程架构

时间: 2024-10-18 02:36:11

数据层全栈式编程架构的相关文章

CRUD全栈式编程架构之界面层的设计

Layout的设计 模板模式 mvc的模板特别类似设计模式中模板方法模式,结合Layout中RenderSection和RenderBody方法可以将部分html展现逻辑延迟到具体的视图页面去实现里面实现.结合我们增删改查的逻辑,我们的用户界面,我们将页面分为这几个区域,实现部分逻辑以后,部分留给具体的页面去实现.例如图片中新增,编辑,删除,导入,导出,查询都是架构自带的操作,至于复制就给页面扩展,查询条件也留给具体的页面中扩展,模板中给出RenderSection即可. 执行顺序 这个执行顺序

CRUD全栈式编程架构之服务层的设计

服务层代码 首先我先放出2个主要类的代码再分别讲解 接口 using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using Coralcode.Framework.Models; using Coralcode.Framework.Page; namespace Coralcode.Framework.Services

CRUD全栈式编程架构之MVC的扩展设计

MVC执行流程 路由的扩展 我理解的路由作用有以下几个 Seo优化,用“/”分开的url爬虫更爱吃 物理和逻辑文件分离,url不再按照文件路径映射 Controller,Action的选择 MVC路由的扩展 实话实说MVC的路由我很少去做扩展,在MVC4时代,还会去重写掉url的大小写,而在MVC5之后,MVC自带了配置去小写化url.不过有一个配置还是必须要提一下那就是Area,在你的系统达到一定规模之后,Controllers通过Area来管理将会变得更容易.这里给出我的Area扩展,很简单

CRUD全栈式编程架构之控制器的设计

页面 这里界面我采用jquery miniui来做的,当你完全了解了整个设计之后可以轻松切换到其他的js框架,个人认为类似muniui,easyui等等这类可以将web界面做得和winform类似的框架,特别适合做后台管理系统.要讨论controller的设计必须结合界面,这里我给出界面截图和控制器的代码,这一篇主要讲控制器的代码,下一篇再讲界面的设计. 上一篇忘记说了,IVeiwModel是一个dto或者说viewmode的接口,我的应用里面一般不严格区分viewmode和dto,这个接口之后

CRUD全栈式编程概述

业务场景 CRUD,从数据驱动的角度几乎所有的的业务都是在做这样的事情.  几乎所有的操作都是在做对表的增删该查.  假设我们将数据库数据规个类:  分为基础/配置数据和业务/增长数据,或者说静态数据和动态数据.  其中静态数据是由后台管理员编辑的产生,动态数据是由客户产生.  那么这部分中的静态数据往往伴随着完整的增删改查逻辑.  完整的增删改查逻辑指的是,有对数据库某个表数据的查询.  一条或者几条数据的添加,删除,修改.  再直白一点就是有个界面,上面有查询,添加,删除,修改,导入,导出的

基于NodeJS的全栈式开发

随着不同终端(Pad/Mobile/PC)的兴起,对开发人员的要求越来越高,纯浏览器端的响应式已经不能满足用户体验的高要求,我们往往需要针对不同的终端开发定制的版本.为了提升开发效率,前后端分离的需求越来越被重视,后端负责业务/数据接口,前端负责展现/交互逻辑,同一份数据接口,我们可以定制开发多个版本. 这个话题最近被讨论得比较多,阿里有些BU也在进行一些尝试.讨论了很久之后,我们团队决定探索一套基于NodeJS的前后端分离方案,过程中有一些不断变化的认识以及思考,记录在这里,也希望看到的同学参

也谈基于NodeJS的全栈式开发(基于NodeJS的前后端分离)

随着不同终端(Pad/Mobile/PC)的兴起,对开发人员的要求越来越高,纯浏览器端的响应式已经不能满足用户体验的高要求,我们往往需要针对不同的终端开发定制的版本.为了提升开发效率,前后端分离的需求越来越被重视,后端负责业务/数据接口,前端负责展现/交互逻辑,同一份数据接口,我们可以定制开发多个版本. 这个话题最近被讨论得比较多,阿里有些BU也在进行一些尝试.讨论了很久之后,我们团队决定探索一套基于NodeJS的前后端分离方案,过程中有一些不断变化的认识以及思考,记录在这里,也希望看到的同学参

基于NodeJS的全栈式开发(基于NodeJS的前后端分离)

也谈基于NodeJS的全栈式开发(基于NodeJS的前后端分离) 前言 为了解决传统Web开发模式带来的各种问题,我们进行了许多尝试,但由于前/后端的物理鸿沟,尝试的方案都大同小异.痛定思痛,今天我们重新思考了“前后端”的定义,引入前端同学都熟悉的NodeJS,试图探索一条全新的前后端分离模式. 随着不同终端(Pad/Mobile/PC)的兴起,对开发人员的要求越来越高,纯浏览器端的响应式已经不能满足用户体验的高要求,我们往往需要针对不同的终端开发定制的版本.为了提升开发效率,前后端分离的需求越

如何学习(1):构建全栈式知识结构

有次下班到家楼下等电梯,碰巧一位妈妈抱到两岁的小女孩在看旁边的宣传画.这时电梯还没到,这位妈妈就指着海报上的字读给小女孩,"这是太阳,那是月亮"--,想借这个机会教小孩认字. 这是中国式的.传统的教学方法,其实我对这种死记硬背的方法不怀好意,于是在电梯上开起了小差,为什么这种方法效果不好,不招受教者的讨好呢. 如果我是教自己的小女儿认字,我会怎么教呢? "牛牛,你看,上面画的是太阳.你知道吗?太阳公公每天很早就起床了,大地才开始暖起来,小朋友们才可以出来玩耍.到了晚上,太阳公