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

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

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

SysPermissonInfor.cs

  1. public class SysPermissonInfor
  2. {
  3. public SysPermissonInfor() {
  4.  
  5. }
  6.  
  7. /// <summary>
  8. /// 菜单权限编号
  9. /// </summary>
  10. [Key]
  11. [DatabaseGeneratedAttribute(DatabaseGeneratedOption.None)]
  12. public int id { get; set; }
  13. /// <summary>
  14. /// 父菜单权限编号
  15. /// </summary>
  16. [Required] //非空声明
  17. public int parentId { get; set; }
  18. /// <summary>
  19. /// 菜单名称
  20. /// </summary>
  21. [StringLength()] //最大长度
  22. [Required] //非空声明
  23. public string menuName { get; set; }
  24. /// <summary>
  25. /// 区域名
  26. /// </summary>
  27. [StringLength()] //最大长度
  28. public string areaName { get; set; }
  29. /// <summary>
  30. /// 控制器名
  31. /// </summary>
  32. [StringLength()] //最大长度
  33. public string controllerName { get; set; }
  34. /// <summary>
  35. /// 方法名
  36. /// </summary>
  37. [StringLength()] //最大长度
  38. public string actionName { get; set; }
  39. /// <summary>
  40. /// 图标类名
  41. /// </summary>
  42. [StringLength()] //最大长度
  43. public string iconClassName { get; set; }
  44. /// <summary>
  45. /// 备注
  46. /// </summary>
  47. [StringLength()] //最大长度
  48. public string remarkContent { get; set; }
  49. /// <summary>
  50. /// 创建时间
  51. /// </summary>
  52. public Nullable<System.DateTime> addTime { get; set; }
  53. /// <summary>
  54. /// 排序标记
  55. /// </summary>
  56. public Nullable<int> sortFlag { get; set; }
  57. /// <summary>
  58. /// 隐藏标记
  59. /// </summary>
  60. public Nullable<int> delFlag { get; set; }
  61.  
  62. public virtual ICollection<SysRoleInfor> sysRoleInfor { get; set; }
  63. }

SysRoleInfor.cs

  1. public class SysRoleInfor
  2. {
  3. public SysRoleInfor() {
  4.  
  5. }
  6.  
  7. /// <summary>
  8. /// 角色编号
  9. /// </summary>
  10. [Key]
  11. [DatabaseGeneratedAttribute(DatabaseGeneratedOption.Identity)]
  12. public int id { get; set; }
  13. /// <summary>
  14. /// 角色名称
  15. /// </summary>
  16. [StringLength()] //最大长度
  17. [Required] //非空声明
  18. public string roleName { get; set; }
  19. /// <summary>
  20. /// 角色说明
  21. /// </summary>
  22. [StringLength()] //最大长度
  23. public string roleRemark { get; set; }
  24. /// <summary>
  25. /// 录入时间
  26. /// </summary>
  27. public Nullable<System.DateTime> addTime { get; set; }
  28. /// <summary>
  29. /// 隐藏标记
  30. /// </summary>
  31. public Nullable<int> delFlag { get; set; }
  32.  
  33. /// <summary>
  34. ///多个用户可以对应一个角色
  35. /// </summary>
  36. public virtual ICollection<SysUserInfor> sysUserInfor { get; set; }
  37. /// <summary>
  38. /// 一个权限对应一个角色
  39. /// </summary>
  40. public virtual SysPermissonInfor sysPermissonInfor { get; set; }
  41.  
  42. }

SysUserInfor.cs

  1. public class SysUserInfor
  2. {
  3. public SysUserInfor() {
  4.  
  5. }
  6.  
  7. /// <summary>
  8. /// 操作员编号 自增
  9. /// </summary>
  10. [Key]
  11. [DatabaseGeneratedAttribute(DatabaseGeneratedOption.Identity)]
  12. public int id { get; set; }
  13. /// <summary>
  14. /// 操作员帐号
  15. /// </summary>
  16. [StringLength()] //最大长度
  17. [Required] //非空声明
  18. public string userAccount { get; set; }
  19. /// <summary>
  20. /// 操作员密码
  21. /// </summary>
  22. [StringLength()] //最大长度
  23. [Required] //非空声明
  24. public string userPwd { get; set; }
  25. /// <summary>
  26. /// 姓名
  27. /// </summary>
  28. [StringLength()] //最大长度
  29. [Required] //非空声明
  30. public string userRealName { get; set; }
  31. /// <summary>
  32. /// 性别 0:女 1:男
  33. /// </summary>
  34. public Nullable<int> userSex { get; set; }
  35. /// <summary>
  36. /// 联系方式
  37. /// </summary>
  38. [StringLength()] //最大长度
  39. public string userPhone { get; set; }
  40. /// <summary>
  41. /// 备注说明 长度500
  42. /// </summary>
  43. [StringLength()] //最大长度
  44. public string userRemark { get; set; }
  45. /// <summary>
  46. ///
  47. /// </summary>
  48. public Nullable<System.DateTime> addTime { get; set; }
  49. /// <summary>
  50. /// 隐藏标记 0:正常 1:隐藏
  51. /// </summary>
  52. public Nullable<int> delFlag { get; set; }
  53.  
  54. /// <summary>
  55. ///一个用户对应一个角色
  56. /// </summary>
  57. public SysRoleInfor sysRoleInfor { get; set; }
  58. }

其次创建一个DemoDbContext类

  1. public class DemoDbContext : DbContext
  2. {
  3. public DemoDbContext()
  4. : base("name=ConncodeFirst")
  5. {
  6. //数据库不存在则生成数据库
  7. Database.SetInitializer<DemoDbContext>(new CreateDatabaseIfNotExists<DemoDbContext>());
  8.  
  9. }
  10. public DbSet<SysUserInfor> SysUserInfor { get; set; }
  11. public DbSet<SysRoleInfor> SysRoleInfor { get; set; }
  12. public DbSet<SysPermissonInfor> SysPermissonInfor { get; set; }
  13.  
  14. protected override void OnModelCreating(DbModelBuilder modelBuilder)
  15. {
  16. base.OnModelCreating(modelBuilder);
  17. }
  18.  
  19. }

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

  1. <connectionStrings>
  2. <add name="ConncodeFirst" connectionString="server=localhost;uid=sa;pwd=123456;database=CodeFirst_Task" providerName="System.Data.SqlClient"/>
  3. </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. c#生成AVI自动设置压缩格式,不调用AVISaveOptions

    工作中遇到生成AVI视频的项目,代码中会调用AVISaveOptions来设置压缩格式,针对单个文件还好说,但是批量生成视频的时候,每一个都要设置格式, 体验不是很好,经过查询资料问题得到解决 最开始 ...

  2. MyEclipse,Eclipse注释规范模板

    注释的作用:myeclipse中java文件头注释格式设置,最终可用于javadoc.exe生成API文档,同时提高了代码的可读性 设置方法: windows->preferences-> ...

  3. Hihocoder #1479 : 三等分 树形DP

    三等分  描述 小Hi最近参加了一场比赛,这场比赛中小Hi被要求将一棵树拆成3份,使得每一份中所有节点的权值和相等. 比赛结束后,小Hi发现虽然大家得到的树几乎一模一样,但是每个人的方法都有所不同.于 ...

  4. 阳性比例 mysql CASE UNION ALL

    阳性比例 mysql CASE UNION ALL SELECT t.*,t.type_0/all_ FROM ( SELECT FROM_UNIXTIME(create_time,'%Y-%m-%d ...

  5. 【LIS】Luogu P1020 导弹拦截

    昨天晚上看蓝书,看到了LIS问题的优化解法. 是比O(n方)更快的解法,实际上是一个常数优化. 先讲一下朴素的解法: 一个集合a,a[i]是第i个元素.设dp[i]为以编号为i的元素结尾的最长不上升子 ...

  6. E20170602-ts

    questionnaire  n. 调查问卷; 调查表;  アンケート不是英语 collection   n. 征收; 收集,采集; 收藏品; 募捐; association   n. 联想; 协会, ...

  7. bzoj 1651: [Usaco2006 Feb]Stall Reservations 专用牛棚【贪心+堆||差分】

    这个题方法还挺多的,不过洛谷上要输出方案所以用堆最方便 先按起始时间从小到大排序. 我用的是greater重定义优先队列(小根堆).用pair存牛棚用完时间(first)和牛棚编号(second),每 ...

  8. Akka源码分析-Akka-Streams-GraphStage

    上一篇博客中我们介绍了ActorMaterializer的一小部分源码,其实分析的还是非常简单的,只是初窥了Materializer最基本的初始化过程及其涉及的基本概念.我们知道在materializ ...

  9. NET 编程题

    1.C#编写创建一个线程的代码 using System; using System.IO; using System.Threading ; class MyThread{ public int c ...

  10. excel 录入oracle 方法

    http://blog.itpub.net/28602568/viewspace-1797410/ 1.方法1:外部表 1.将excel另存为.txt格式(2种txt 格式都可以),再传到数据库dir ...