第三篇:Entity Framework CodeFirst & Model 映射 续篇 EntityFramework Power Tools 工具使用
上一篇 第二篇:Entity Framework CodeFirst & Model 映射 主要介绍以Fluent API来实作EntityFramework CodeFirst,得到了大家一些支持,其中就有一位同学就提出。熟悉了EntityFramework CodeFirst 原理,就可以用微软的工具来生产代码。是的,今天就来讲一下,由微软EntityFramework小组开发的为EntityFramework CodeFirst Visual Studio小插件 “Entity Framework Power Tools”.
Entity Framework Power Tools 现在Bate4 版,估计也不会更新,因为现在紧锣密鼓的 开发Entity Framework 7。不过没有关系,Bate4 已经很稳定了,很能够解决Fluent API 繁琐的Model,Mapping 创建的工作。是一款很不错生产力工具,下面就听我慢慢的讲怎么用咯。
一. Entity Framework Power Tools Bate4 安装
1. 打开Visual Studio 2013 ,选择 工具 菜单,再选择 扩展和更新。
2. 选择左边菜单的联机——在右上的搜索栏中输入 power tool ,在搜索结果中找到,Entity Framework Power Tools Bate4 下载安装,然后重启。
如果家里网速不行,搜索 转了半天 也不出来的话,我这里也提供独立安装包 下载 :http://files.cnblogs.com/files/davidzhou/EFPowerTools.zip 解压安装即可。
二. Entity Framework Power Tools 的使用
1. 重新打开 Visual Studio 2013 ,新建 “EntityFrameworkPowerToolsSample” 解决方案,然后添加“EntityFrameworkPowerTools.Models” 类库项目。
2. 右击 “EntityFrameworkPowerTools.Models” 类库项目,会多出来一个“Entity Framework” 菜单
选择 “Entity Framework” 菜单下的“Reverse Engineer Code First” 选项,会弹出 数据库 连接属性界面,配置你要连接的数据库服务器,数据库。
我这里配置的是,我本机的 “EntityFrameworkSample” 数据库。
点击 “确定” 不出意外就会产生Entity Framework CodeFirst 相关的代码。如果没有安装Entity Framework,在生成之前会自动给安装。
3. 生成代码如下
Sample_Order (数据模型)
using System;
using System.Collections.Generic; namespace EntityFrameworkPowerTools.Models.Models
{
public partial class Sample_Order
{
public System.Guid OrderGuid { get; set; }
public string OrderNo { get; set; }
public string OrderCreator { get; set; }
public System.DateTime OrderDateTime { get; set; }
public string OrderStatus { get; set; }
public string Description { get; set; }
public string Creator { get; set; }
public System.DateTime CreateDateTime { get; set; }
public string LastModifier { get; set; }
public Nullable<System.DateTime> LastModifiedDateTime { get; set; }
}
}
Sample_OrderMap (映射配置)
using System.Data.Entity.ModelConfiguration; namespace EntityFrameworkPowerTools.Models.Models.Mapping
{
public class Sample_OrderMap : EntityTypeConfiguration<Sample_Order>
{
public Sample_OrderMap()
{
// Primary Key
this.HasKey(t => t.OrderGuid); // Properties
this.Property(t => t.OrderNo)
.IsRequired()
.HasMaxLength(); this.Property(t => t.OrderCreator)
.IsRequired()
.HasMaxLength(); this.Property(t => t.OrderStatus)
.IsRequired()
.HasMaxLength(); this.Property(t => t.Description)
.HasMaxLength(); this.Property(t => t.Creator)
.IsRequired()
.HasMaxLength(); this.Property(t => t.LastModifier)
.HasMaxLength(); // Table & Column Mappings
this.ToTable("Sample_Order");
this.Property(t => t.OrderGuid).HasColumnName("OrderGuid");
this.Property(t => t.OrderNo).HasColumnName("OrderNo");
this.Property(t => t.OrderCreator).HasColumnName("OrderCreator");
this.Property(t => t.OrderDateTime).HasColumnName("OrderDateTime");
this.Property(t => t.OrderStatus).HasColumnName("OrderStatus");
this.Property(t => t.Description).HasColumnName("Description");
this.Property(t => t.Creator).HasColumnName("Creator");
this.Property(t => t.CreateDateTime).HasColumnName("CreateDateTime");
this.Property(t => t.LastModifier).HasColumnName("LastModifier");
this.Property(t => t.LastModifiedDateTime).HasColumnName("LastModifiedDateTime");
}
}
}
EntityFrameworkSampleContext (DbContext)
using System.Data.Entity;
using System.Data.Entity.Infrastructure;
using EntityFrameworkPowerTools.Models.Models.Mapping; namespace EntityFrameworkPowerTools.Models.Models
{
public partial class EntityFrameworkSampleContext : DbContext
{
static EntityFrameworkSampleContext()
{
Database.SetInitializer<EntityFrameworkSampleContext>(null);
} public EntityFrameworkSampleContext()
: base("Name=EntityFrameworkSampleContext")
{
} public DbSet<Sample_Order> Sample_Order { get; set; } protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
modelBuilder.Configurations.Add(new Sample_OrderMap());
}
}
}
怎么样是不是代码,跟上一篇,代码差不多啊。只是文件的名称不同而已,如果想调整项目结构,像上一篇一样,你可以把 EntityFramework Power Tools 生产代码拷贝过去,稍作调整就可以了。
当然EntityFramework Power Tools 还可以自定义模板,跟自己写T4模板一样,来实现自己想要规则。我这里就不再做详细讲解了,大家自己摸索一下。
然后本篇的源代码 : http://pan.baidu.com/s/1c2K4R8s
第三篇:Entity Framework CodeFirst & Model 映射 续篇 EntityFramework Power Tools 工具使用的更多相关文章
- 第二篇:Entity Framework CodeFirst & Model 映射
前一篇 第一篇:Entity Framework 简介 我有讲到,ORM 最关键的 Mapping,也提到了最早实现Mapping的技术,就是 特性 + 反射,那Entity Framework 实现 ...
- 第三篇 Entity Framework Plus 之 Query Cache
离上一篇博客,快一周,工作太忙,只能利用休息日来写一些跟大家分享,Entity Framework Plus 组件系列文章,之前已经写过两篇 第一篇 Entity Framework Plus 之 A ...
- entity framework codefirst 用户代码未处理DataException,InnerException基础提供程序在open上失败,数据库生成失败
警告:这是一个入门级日志,如果你很了解CodeFirst,那请绕道 背景:这篇日志记录我使用Entity FrameWork CodeFirst时出现的错误和解决问题的过程,虽然有点曲折……勿喷 备注 ...
- Entity Framework CodeFirst数据迁移
前言 紧接着前面一篇博文Entity Framework CodeFirst尝试. 我们知道无论是“Database First”还是“Model First”当模型发生改变了都可以通过Visual ...
- 第二篇 Entity Framework Plus 之 Query Future
从性能的角度出发,能够减少 增,删,改,查,跟数据库打交道次数,肯定是对性能会有所提升的(这里单纯是数据库部分). 今天主要怎样减少Entity Framework查询跟数据库打交道的次数,来提高查询 ...
- Entity Framework Code-First(20):Migration
Migration in Code-First: Entity framework Code-First had different database initialization strategie ...
- How to: Supply Initial Data for the Entity Framework Data Model 如何:为EF数据模型提供初始数据
After you have introduced a data model, you may need to have the application populate the database w ...
- ADO.NET Entity Framework CodeFirst 如何输出日志(EF 5.0)
ADO.NET Entity Framework CodeFirst 如何输出日志(EF4.3) 用的EFProviderWrappers ,这个组件好久没有更新了,对于SQL执行日志的解决方案的需求 ...
- Entity Framework : The model backing the '' context has changed since the database was created
1.采用code first 做项目时,数据库已经生成,后期修改数据库表结构.再次运行时出现一下问题: Entity Framework : The model backing the '' cont ...
随机推荐
- 使用ubuntu作为web开发环境的一些感受
从ms-dos,win95,win98,winMe,winXp,vista,win7,win10我都有使用的经历,我使用时间最长的应属winxp,其次是win7,说实话,我觉得这两个系统是微软做的最好 ...
- 用javascript 写个函数返回一个页面里共使用了多少种HTML 标签
今天我无意间看到一个面试题: 如何用javascript 写个函数返回一个页面里共使用了多少种HTML 标签? 不知你看到 是否蒙B了,如果是我 面试,肯定脑子嗡嗡的响.... 网上搜了搜也没有找到答 ...
- 免费开源的DotNet二维码操作组件ThoughtWorks.QRCode(.NET组件介绍之四)
在生活中有一种东西几乎已经快要成为我们的另一个电子”身份证“,那就是二维码.无论是在软件开发的过程中,还是在普通用户的日常中,几乎都离不开二维码.二维码 (dimensional barcode) , ...
- 微信小程序监控 - HotApp统计
HotApp小程序统计,第一个专业的微信第三方小程序监控统计工具 1.什么是HotApp小程序统计 HotApp小程序统计是第一个微信第三方小程序统计工具,就像做android 和 ios开发的人知道 ...
- git远程库GitHub
首先,注册一个GitHub(github.com)帐号,免费获得Git远程仓库 由于本地Git仓库和GitHub仓库之间的传输是通过SSH加密的,所以,需要一点设置: 第1步:创建SSH Key.在用 ...
- 【完全开源】知乎日报UWP版(上篇):界面设计、官方API分析
目录 说明 使用Fiddler分析android版API 部分效果图 关于源码 说明 在做博客园UWP版的时候其实就有做知乎日报的打算了,前段时间一直出差,在酒店里用Fiddler简单的分析了一下An ...
- 修复IE11首页被恶意篡改的问题
前几天为了测试一个程序,把系统换成了Windows10,Windows10自带了微软的新浏览器Edge和IE11,用来其实也没什么太多感觉了,我习惯于Chrome,但有些东西还是得用IE,比如网银之类 ...
- ASP.NET MVC Model绑定(三)
ASP.NET MVC Model绑定(三) 前言 看过前两篇的朋友想必对Model绑定有个大概的了解,然而MVC框架给我们提供了更高的可扩展性的提供程序编程模式,也就是本篇的主题了,会讲解一下Mod ...
- 给WinForm窗体添加快捷键 响应回车键、空格键
1.设置窗体KeyPreview属性为True 2.添加窗体的KeyDown事件 /// <summary> /// 窗体的keydown事件响应 添加快捷键 /// </summa ...
- 使用自定义 classloader 的正确姿势
详细的原理就不多说了,网上一大把, 但是, 看了很多很多, 即使看了jdk 源码, 说了罗里吧嗦, 还是不很明白: 到底如何正确自定义ClassLoader, 需要注意什么 ExtClassLoade ...