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. ps图片怎样实现渐变

    首先我先将一副图片展示给大家: 我所做的效果是想把图片做成渐变.而不改变中间图片的颜色效果. 接下来我来说明一下我的所做思路. 首先将图片中间部分选择出来.然后复制成一个图层. 详细操作是用魔棒进行反 ...

  2. 基于AR谱特征的声目标识别

    本文第一部分先解释AR谱,但并不会给出太多的细节,第二部分介绍几种常见的语音中的特征.有些在之前的博文中已经用过.诸如过零率. 第三部分给出实际操作的过程及识别的效果.本文的目标是通过对DSP採集的声 ...

  3. ORA-00907: 缺失右括号(通用解决办法)

    PL/SQL 的SQL语句可以执行,但是放在hibernate中,后台打印,出现了错误. 错误的SQL解析:黄色为错误部分 Hibernate:      select         examine ...

  4. HDU 3308 线段树单点更新+区间查找最长连续子序列

    LCIS                                                              Time Limit: 6000/2000 MS (Java/Oth ...

  5. 图片存储系统TFS

    1 TFS和GFS比较 1.1 GFS的应用场景 第一,百万级别的文件,并且是大文件,文件都是100MB以上,1G级别的文件很常见. 第二,集群是建立在商业计算机之上,并不可靠,监控各个节点的状态,当 ...

  6. Credit Risk Scorecards Credit Risk Modeling 评分卡 KS AR

    https://cn.mathworks.com/help/finance/creditscorecard.validatemodel.html?requestedDomain=www.mathwor ...

  7. 容器HashSet原理(学习)

    一.概述 使用HashMap存储,非线程安全: 二.实现 HashSet 底层使用 HashMap 来保存所有元素,因此 HashSet 的实现比较简单,相关 HashSet 的操作,基本上都是直接调 ...

  8. 牛了个逼,phpstorm查询技巧

    两次shift,会弹出最近常用的文件. 可以查询按照方法名,类名,文件名等进行查询. Ctrl+E可以查看最近使用的文件. Ctrl+Shift+E可以查看最近修改的文件. Ctrl+shift+N ...

  9. iOS开发-多台机器共用证书问题

    今天又被证书的问题卡壳了: 在公司的电脑上申请的开发.发布证书,回家用自己的电脑从苹果开发者中心上将证书和配置文件都下载下来提示用不了,弄了很久才想起.p12文件,必须从申请证书的电脑上导出,导入到自 ...

  10. WinForm里面连接Oracle数据库

    WinForm里面连接Oracle数据库 string oradb = "Data Source=(DESCRIPTION="             + "(ADDRE ...