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. Appro DM8127 IPNC 挂载NFS遇到的问题及解决

    对于Appro DM8127 IPNC,默认的启动方式是NAND is used for booting kernel and NAND is used as root filesystem 为了调试 ...

  2. bzoj3612 [Heoi2014]平衡——整数划分

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3612 看了好久才弄清楚题意... 原来整数划分就是这样的啊:https://blog.csd ...

  3. 基于JWT机制的单点登录

    使用JWT实现单点登录时,需要注意token时效性.token是保存在客户端的令牌数据,如果永久有效,则有被劫持的可能.token在设计的时候,可以考虑一次性有效或一段时间内有效.如果设置有效时长,则 ...

  4. MySQL 启动服务和登陆参数

    启动MySQL服务:net start mysql; 停止MySQL服务:net stop mysql; 参数 描述 -D,--database=name 打开指定数据库 --delimiter=na ...

  5. 基于CentOS7.5的 Rsync 服务详解

    第1章 Rsync概述 1.1 Rsync基本概述 rsync是一款开源的备份工具,可以在不同服务器(主机)之间进行同步备份, 可实现完全备份与增量备份,因此非常适合用于架构集中式备份或异地备份等应用 ...

  6. mysql插入二千万的测试数据进行测试,int和datetime比较

    时间存储用int和datetime哪个字段更合适,建立下面的两个表 测试环境是内存2个G,一核的虚拟机 CREATE TABLE `test_inttime` ( `id` int(11) NOT N ...

  7. python自动化测试学习笔记-6excel操作xlwt、xlrd、xlutils模块

    python中通过xlwt.xlrd和xlutils操作xls xlwt模块用于在内存中生成一个xls/xlsx对象,增加表格数据,并把内存中的xls对象保存为本地磁盘xls文件; xlrd模块用于把 ...

  8. 如何快速部署Oracle Database

    Oracle Database在Linux系统上的安装是每一个初学者都必须面临的问题,只有正确的配置好了环境,才能进行后续的深入学习.本文旨在说明如何快速的部署Oracle的单实例环境,对于初学者,还 ...

  9. MVC的学习-EF的认识

    1.什么是EF EF又称持久层框架:平时C#定义的变量是保存到内存中的,一断电就没有了.而持久的意思是数据保存到硬盘盘里(数据库的sql查询是在硬盘里进行的,所以速度很慢).EF帮我们将一个对象保存到 ...

  10. 微信小程序授权 获取用户的openid和session_key【后端使用java语言编写】,我写的是get方式,目的是测试能否获取到微信服务器中的数据,后期我会写上post请求方式。

    在这里给大家分享下我的心得,1.写代码前一定要对整个流程有个了解.我就是因为在先不了解整个过程中去ctrl+c+v他人的博客代码,花费很多无用的时间去处理还不知道能不能跑的起来的代码. 2.本人比较喜 ...