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. 【POJ 1275】 Cashier Employment(差分约束系统的建立和求解)

    [POJ 1275] Cashier Employment(差分约束系统的建立和求解) Cashier Employment Time Limit: 1000MS   Memory Limit: 10 ...

  2. 洛谷P2668 斗地主==codevs 4610 斗地主[NOIP 2015 day1 T3]

    P2668 斗地主 326通过 2.6K提交 题目提供者洛谷OnlineJudge 标签搜索/枚举NOIp提高组2015 难度提高+/省选- 提交该题 讨论 题解 记录 最新讨论 出现未知错误是说梗啊 ...

  3. bzoj3550: [ONTAK2010]Vacation&&bzoj3112: [Zjoi2013]防守战线

    学了下单纯形法解线性规划 看起来好像并不是特别难,第二个code有注释.我还有...*=-....这个不是特别懂 第一个是正常的,第二个是解对偶问题的 #include<cstdio> # ...

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

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

  5. 在java中除去字符串(String)中的换行字符(\r \n \t)

    我们先来看几个例子: 例1: public class Test { public static void main(String[] args) { String s = "'sds gd ...

  6. lucene .doc文件格式解析——见图

    摘自:http://forfuture1978.iteye.com/blog/546841 4.2.2. 文档号及词频(frq)信息 文档号及词频文件里面保存的是倒排表,是以跳跃表形式存在的. 此文件 ...

  7. Java 并发 —— Thread、Executor、线程池

    Java 线程池: ThreadPoolExecutor,创建此线程池的方法: new Executors.newCachedThreadPool():尽量避免使用,其无法控制线程数量, Schedu ...

  8. 基于Spark和Tensorflow构建DCN模型进行CTR预测

    实验介绍 数据采用Criteo Display Ads.这个数据一共11G,有13个integer features,26个categorical features. Spark 由于数据比较大,且只 ...

  9. CodeForces 382C Arithmetic Progression (排序+分类讨论)

    题意:给出一个长度为n的序列,表示有n张卡片,上面的数字,现在还有一张卡片,上面没有数字,问说可以写几种数字在这张卡片上面, 使得n+1张卡片上的数字可以排列成一个等差数列,有无限多种时输出-1. 析 ...

  10. 微信小程序setData的使用,通过[...]进行动态key赋值

    首先先介绍一下微信小程序Page.prototype.setData(Object data, Function callback)的讲解: setData函数用于将数据从逻辑层发送到视图层(异步), ...