Code First(代码先行)。它思想就是先定义模型中的类,再通过这些类生成数据库。这种开发模式适合于全新的项目,它使得我们可以以代码为核心进行设计而不是先构造数据库。

EF中创建数据库的表必须要有主键~!否则 将不成功。

首先我们创建3个实体类:

SysPermissonInfor.cs

     public class SysPermissonInfor
{
public SysPermissonInfor() { } /// <summary>
/// 菜单权限编号
/// </summary>
[Key]
[DatabaseGeneratedAttribute(DatabaseGeneratedOption.None)]
public int id { get; set; }
/// <summary>
/// 父菜单权限编号
/// </summary>
[Required] //非空声明
public int parentId { get; set; }
/// <summary>
/// 菜单名称
/// </summary>
[StringLength()] //最大长度
[Required] //非空声明
public string menuName { get; set; }
/// <summary>
/// 区域名
/// </summary>
[StringLength()] //最大长度
public string areaName { get; set; }
/// <summary>
/// 控制器名
/// </summary>
[StringLength()] //最大长度
public string controllerName { get; set; }
/// <summary>
/// 方法名
/// </summary>
[StringLength()] //最大长度
public string actionName { get; set; }
/// <summary>
/// 图标类名
/// </summary>
[StringLength()] //最大长度
public string iconClassName { get; set; }
/// <summary>
/// 备注
/// </summary>
[StringLength()] //最大长度
public string remarkContent { get; set; }
/// <summary>
/// 创建时间
/// </summary>
public Nullable<System.DateTime> addTime { get; set; }
/// <summary>
/// 排序标记
/// </summary>
public Nullable<int> sortFlag { get; set; }
/// <summary>
/// 隐藏标记
/// </summary>
public Nullable<int> delFlag { get; set; } public virtual ICollection<SysRoleInfor> sysRoleInfor { get; set; }
}

SysRoleInfor.cs

     public class SysRoleInfor
{
public SysRoleInfor() { } /// <summary>
/// 角色编号
/// </summary>
[Key]
[DatabaseGeneratedAttribute(DatabaseGeneratedOption.Identity)]
public int id { get; set; }
/// <summary>
/// 角色名称
/// </summary>
[StringLength()] //最大长度
[Required] //非空声明
public string roleName { get; set; }
/// <summary>
/// 角色说明
/// </summary>
[StringLength()] //最大长度
public string roleRemark { get; set; }
/// <summary>
/// 录入时间
/// </summary>
public Nullable<System.DateTime> addTime { get; set; }
/// <summary>
/// 隐藏标记
/// </summary>
public Nullable<int> delFlag { get; set; } /// <summary>
///多个用户可以对应一个角色
/// </summary>
public virtual ICollection<SysUserInfor> sysUserInfor { get; set; }
/// <summary>
/// 一个权限对应一个角色
/// </summary>
public virtual SysPermissonInfor sysPermissonInfor { get; set; } }

SysUserInfor.cs

public class SysUserInfor
{
public SysUserInfor() { } /// <summary>
/// 操作员编号 自增
/// </summary>
[Key]
[DatabaseGeneratedAttribute(DatabaseGeneratedOption.Identity)]
public int id { get; set; }
/// <summary>
/// 操作员帐号
/// </summary>
[StringLength()] //最大长度
[Required] //非空声明
public string userAccount { get; set; }
/// <summary>
/// 操作员密码
/// </summary>
[StringLength()] //最大长度
[Required] //非空声明
public string userPwd { get; set; }
/// <summary>
/// 姓名
/// </summary>
[StringLength()] //最大长度
[Required] //非空声明
public string userRealName { get; set; }
/// <summary>
/// 性别 0:女 1:男
/// </summary>
public Nullable<int> userSex { get; set; }
/// <summary>
/// 联系方式
/// </summary>
[StringLength()] //最大长度
public string userPhone { get; set; }
/// <summary>
/// 备注说明 长度500
/// </summary>
[StringLength()] //最大长度
public string userRemark { get; set; }
/// <summary>
///
/// </summary>
public Nullable<System.DateTime> addTime { get; set; }
/// <summary>
/// 隐藏标记 0:正常 1:隐藏
/// </summary>
public Nullable<int> delFlag { get; set; } /// <summary>
///一个用户对应一个角色
/// </summary>
public SysRoleInfor sysRoleInfor { get; set; }
}

其次创建一个DemoDbContext类

 public class DemoDbContext : DbContext
{
public DemoDbContext()
: base("name=ConncodeFirst")
{
//数据库不存在则生成数据库
Database.SetInitializer<DemoDbContext>(new CreateDatabaseIfNotExists<DemoDbContext>()); }
public DbSet<SysUserInfor> SysUserInfor { get; set; }
public DbSet<SysRoleInfor> SysRoleInfor { get; set; }
public DbSet<SysPermissonInfor> SysPermissonInfor { get; set; } protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
base.OnModelCreating(modelBuilder);
} }

在mvc的Web.config里的configuration下增加数据库连接:

  <connectionStrings>
<add name="ConncodeFirst" connectionString="server=localhost;uid=sa;pwd=123456;database=CodeFirst_Task" providerName="System.Data.SqlClient"/>
</connectionStrings>

再创建控制器,运行已生成数据库

CodeFrist基础的更多相关文章

  1. CodeFrist基础_迁移更新数据

    一丶自动迁移 第一次启用迁移:NeGet-->Enable-Migrations public DemoDbContext() : base("name=ConncodeFirst&q ...

  2. CodeFrist基础_Fluent Api

    一丶首先新建两个实体类 public class Student { public int StudentKey { get; set; } public string StudentName { g ...

  3. java基础集合经典训练题

    第一题:要求产生10个随机的字符串,每一个字符串互相不重复,每一个字符串中组成的字符(a-zA-Z0-9)也不相同,每个字符串长度为10; 分析:*1.看到这个题目,或许你脑海中会想到很多方法,比如判 ...

  4. node-webkit 环境搭建与基础demo

    首先去github上面下载(地址),具体更具自己的系统,我的是windows,这里只给出windows的做法 下载windows x64版本 下载之后解压,得到以下东西 为了方便,我们直接在这个目录中 ...

  5. js学习笔记:webpack基础入门(一)

    之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...

  6. Golang, 以17个简短代码片段,切底弄懂 channel 基础

    (原创出处为本博客:http://www.cnblogs.com/linguanh/) 前序: 因为打算自己搞个基于Golang的IM服务器,所以复习了下之前一直没怎么使用的协程.管道等高并发编程知识 ...

  7. [C#] C# 基础回顾 - 匿名方法

    C# 基础回顾 - 匿名方法 目录 简介 匿名方法的参数使用范围 委托示例 简介 在 C# 2.0 之前的版本中,我们创建委托的唯一形式 -- 命名方法. 而 C# 2.0 -- 引进了匿名方法,在 ...

  8. HTTPS 互联网世界的安全基础

    近一年公司在努力推进全站的 HTTPS 化,作为负责应用系统的我们,在配合这个趋势的过程中,顺便也就想去搞清楚 HTTP 后面的这个 S 到底是个什么含义?有什么作用?带来了哪些影响?毕竟以前也就只是 ...

  9. Swift与C#的基础语法比较

    背景: 这两天不小心看了一下Swift的基础语法,感觉既然看了,还是写一下笔记,留个痕迹~ 总体而言,感觉Swift是一种前后端多种语言混合的产物~~~ 做为一名.NET阵营人士,少少多多总喜欢通过对 ...

随机推荐

  1. OpenStack QA

    1 能用devstack部署生产环境的OpenStack吗? 不能,记着,不能!有些选项对生产环境不合适.生产环境能够考虑使用Crowbar部署OpenStack.相关文档例如以下:http://op ...

  2. 关于Time Series Database

    今天观察了下clojure之父datomic.com的数据库 有点类似sequence数据库的变种 不过这类数据库,感觉用在移动端会更有市场: 1. 移动端需要这种可以本地存储,无删除,联网只增加,只 ...

  3. OTN / SONET / SDH

    ①OTN(光传送网,OpticalTransportNetwork),是以波分复用技术为基础.在光层组织网络的传送网,是下一代的骨干传送网; ②SONET (Synchronous Optical N ...

  4. YTU 2629: E1 一种颜色,三个分量

    2629: E1 一种颜色,三个分量 时间限制: 1 Sec  内存限制: 128 MB 提交: 300  解决: 226 题目描述 在计算机中,常用三种基色红(R).绿(G).蓝(B)的混合来表示颜 ...

  5. [翻译]NUnit---Equality Asserts&& Identity Asserts (四)

    Equality Asserts 这些方法测试两个参数是否相等.语言不自动装修的普通类型可以使用对应的重载的方法. Comparing Numerics of Different Types 比较两个 ...

  6. C# winfrom TCP 服务端和客户端(链接)

    1.C#Winform TCP 之服务端: 可以参考下面链接,比较好.第二个链接可以看看,提供了一个思路. http://www.cnblogs.com/guolebin7/archive/2013/ ...

  7. PCB 批量Word转PDF实现方法

    自上次公司电脑中毒带来的影响,导致系统自动生成的Word档PCB出货报告,通过公司邮件服务器以附件的方式发送给客户后,客户是无法打开或打开缓慢的现象,如果将Word档转为PDF后在客户端是可以正常打开 ...

  8. RandomAccessFile使用场景及总结

    大家在学到Java中IO流的时候学到了各种流,对文件的各种操作.但是唯独可能对RandomAccessFile对象不会去过多的研究,那么这个到底有什么用呢? RandomAccessFile的唯一父类 ...

  9. OpenGL 2D模式

    // // left top 这里设置的默认是左上角 // void push_view2d(int left, int top, int width, int height) { //glPushA ...

  10. spring的annotation

    spring容器创建bean对象的方式: 1,使用反射调用无参构造器来创建实例(前提是这个类有无参构造器)(常规方式) 2,通过工厂类获得实例(工厂类实现了接口FactoryBean<?> ...