06 2016 档案

摘要:EF性能渣?这个锅EF不背 作为ORM,必然有性能上的损失,这是取舍问题。但“舍”的性能损失,大到可以用渣形容吗? 微软在设计EF的时候同时考虑了CS和BS,导致部分配置适合A却不适合B,而可能为了让开发者(无论CS系统开发者还是BS系统开发者)体验到这些配置,默认都是开启的。这直接成为部分开发者认为EF性能很渣的重要原因之一。 这篇日志将粗略介绍几个主要配置的作用和适用场景。 最常用的几个主... 阅读全文
posted @ 2016-06-30 11:00 落阳 阅读(814) 评论(0) 推荐(0)
摘要:为什么要有工作单元 在EF中,对实体集合的添加、更新和删除操作都只是内存级别的处理,需要通过db.SaveChanges()来执行数据库更新。这样就可以在SaveChanges之前对不同实体集合进行不同的操作,最后一次性提交到数据库,以保证事务的嵌套(SaveChanges时会自动嵌套事务)。举例来说,EF中可以这样操作db: 1 var db1 = new MasterEntityConte... 阅读全文
posted @ 2016-06-23 10:42 落阳 阅读(680) 评论(0) 推荐(0)
摘要:为什么要设计数据接口 首先来看一下3层的主要逻辑:数据层 => 业务层 => 应用层。作为通用的项目模板,其中最可能按需而大变的就是数据层,因为不同的项目,使用的数据库、数据驱动技术,是很有可能不同的。项目A,MsSql+EF(就像我正在演示的),项目B,也用这套模板,但变成了MySql+ADO.NET,那么就要尽可能地维持项目的整洁,减少需要修改的代码的量和范围。最佳的做法自然就是“数据层暴露出... 阅读全文
posted @ 2016-06-16 17:41 落阳 阅读(510) 评论(0) 推荐(0)
摘要:不多说,完善一下。 完善数据核心层 在数据实体层(SF.Framework.Entity)中,我们以一级文件夹区分了不同数据库的数据实体,如下图: 也是因此,在数据核心层(SF.Framework.DataCore)中定义EF数据上下文(MasterEntityContext)时,特地以Master作为类前缀来进行区分,实体配置工厂(MasterConfigurationFactory)也是... 阅读全文
posted @ 2016-06-16 14:00 落阳 阅读(428) 评论(0) 推荐(0)
摘要:经过前面的工作,系统正变得越来越清晰。 现在有一个问题需要解决。当需要额外增加一个数据表时,我们需要做的操作是: 在实体层创建实体并编译实体层 在核心层运行T4 配置实体 将实体对象关联给EF数据库上下文(定义DbSet) 将实体配置注册给EF配置对象 这过于繁琐,最后2个步骤,强行地把实体关联在EF数据库上下文里,导致了两者的耦合。这篇日志将演示如何将最后2个步骤省略,解放EF数据库上下文,不... 阅读全文
posted @ 2016-06-08 17:33 落阳 阅读(511) 评论(2) 推荐(0)
摘要:基于EntityFramework的数据访问层,我计划细分成数据核心、数据接口和数据实现。 其中数据核心已经在前几个章节中创建,那么在这篇日志里,将演示数据仓储(接口和实现)的实现及封装架构的整个过程。 仓储的作用 仓储的概念请自行搜索了解,我认为它最大的作用就是解耦。没有仓储,就只能直接使用EF数据库上下文对象来操作数据库,而为了“能使用EF数据库上下文对象来操作数据库(各实体库)”,就必须... 阅读全文
posted @ 2016-06-08 10:19 落阳 阅读(633) 评论(4) 推荐(0)
摘要:在前一章节里,我们已经能够对映射字段进行配置了。但在演示中,我们通过删除原数据库让EF重新创建的方式,才把新的字段信息更新(其实是破而后立)到了数据库。这显然无法让人接受。在这篇日志里,将演示“在实体类发生改变时如何自动更新数据库中的表结构”和“在EF创建数据库的时候如何初始化一批数据”。 合并/迁移 合并是指“新的实体模型映射到数据库中,更新其结构”,例如: 新增了实体类,那在数据库中就是... 阅读全文
posted @ 2016-06-06 17:39 落阳 阅读(1455) 评论(0) 推荐(0)
摘要:在前面的章节里,用户表的结构非常简单,没有控制如何映射到数据库。通常,需要对字段的长度、是否可为空甚至特定数据类型进行设置,因为EntityFramework的默认映射规则相对而言比较简单和通用。在这篇日志里,将演示如何对数据实体进行映射配置,并利用T4模板自动创建映射配置类文件。 配置方式 EntityFramework的实体映射配置有2种。 第一种是直接在实体类中以特性的方式进行控制,这些... 阅读全文
posted @ 2016-06-05 18:02 落阳 阅读(829) 评论(2) 推荐(0)
摘要:这篇日志将演示: 1、利用EF的Code First模式,自动创建数据库 2、实现简单的用户登录(不考虑安全仅仅是密码验证) 为什么选择EntityFramework 第一,开发常规中小型系统,能够提高开发效率。 针对小型系统,ORM提高开发效率那是立竿见影。而且linq+lambda的用户体验非常棒,让代码可读性大大增强。即使把linq写得很烂,小系统也无所谓。 针对中型系统,在对ORM有... 阅读全文
posted @ 2016-06-04 00:40 落阳 阅读(2241) 评论(3) 推荐(1)
摘要:EasyUI EasyUI是基于JQuery库的偏js轻型前端UI框架,不了解的读者可以参考官网地址。 在项目中增加JQuery和EasyUI,并在布局页中引用。为了结构清晰,方便日后维护和升级,可以在Scripts下创建jquery文件夹和jquery-easyui文件夹。这里选择1.11.0的JQuery和1.4.3的EasyUI。 特别说明一下,我已经修复了该版本的几个(只能通过修改源码来... 阅读全文
posted @ 2016-06-02 23:24 落阳 阅读(1028) 评论(0) 推荐(0)
摘要:新建ASP.NET MVC项目,解决方案名称Seven,MVC项目名称S.Framework.WebClient。如下图: 创建MVC项时会让你选择身份验证方式,选择无吧,咱要空白干净的MVC项目。是否勾选单元测试随自己喜欢就好。 现在把MVC项目中我们不需要用到的部分移除掉,比如自带的bootstrap、jquery、jquery Validation等,可通过nuget工具来移除。如下图: ... 阅读全文
posted @ 2016-06-02 19:34 落阳 阅读(689) 评论(0) 推荐(2)
摘要:技能需沉淀,文字组织能力需提升。决定写这套日志,回忆、优化、记录和分享。 七色花,当年毕设的名称,算是对梦想的追逐吧。 情怀内容结束,正式开始。 系统定位和目标: 这套系统的定位是应用型管理系统模板。 功能层面来说,其主要目标是实现权限的灵活控制和通用功能的实现; 代码层面来说,其主要目标是以下几点: 1、基于EntityFramework的数据层封装设计和实现 2、En... 阅读全文
posted @ 2016-06-02 15:28 落阳 阅读(1242) 评论(4) 推荐(2)