CodeFrist基础
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基础的更多相关文章
- CodeFrist基础_迁移更新数据
一丶自动迁移 第一次启用迁移:NeGet-->Enable-Migrations public DemoDbContext() : base("name=ConncodeFirst&q ...
- CodeFrist基础_Fluent Api
一丶首先新建两个实体类 public class Student { public int StudentKey { get; set; } public string StudentName { g ...
- java基础集合经典训练题
第一题:要求产生10个随机的字符串,每一个字符串互相不重复,每一个字符串中组成的字符(a-zA-Z0-9)也不相同,每个字符串长度为10; 分析:*1.看到这个题目,或许你脑海中会想到很多方法,比如判 ...
- node-webkit 环境搭建与基础demo
首先去github上面下载(地址),具体更具自己的系统,我的是windows,这里只给出windows的做法 下载windows x64版本 下载之后解压,得到以下东西 为了方便,我们直接在这个目录中 ...
- js学习笔记:webpack基础入门(一)
之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...
- Golang, 以17个简短代码片段,切底弄懂 channel 基础
(原创出处为本博客:http://www.cnblogs.com/linguanh/) 前序: 因为打算自己搞个基于Golang的IM服务器,所以复习了下之前一直没怎么使用的协程.管道等高并发编程知识 ...
- [C#] C# 基础回顾 - 匿名方法
C# 基础回顾 - 匿名方法 目录 简介 匿名方法的参数使用范围 委托示例 简介 在 C# 2.0 之前的版本中,我们创建委托的唯一形式 -- 命名方法. 而 C# 2.0 -- 引进了匿名方法,在 ...
- HTTPS 互联网世界的安全基础
近一年公司在努力推进全站的 HTTPS 化,作为负责应用系统的我们,在配合这个趋势的过程中,顺便也就想去搞清楚 HTTP 后面的这个 S 到底是个什么含义?有什么作用?带来了哪些影响?毕竟以前也就只是 ...
- Swift与C#的基础语法比较
背景: 这两天不小心看了一下Swift的基础语法,感觉既然看了,还是写一下笔记,留个痕迹~ 总体而言,感觉Swift是一种前后端多种语言混合的产物~~~ 做为一名.NET阵营人士,少少多多总喜欢通过对 ...
随机推荐
- c#生成AVI自动设置压缩格式,不调用AVISaveOptions
工作中遇到生成AVI视频的项目,代码中会调用AVISaveOptions来设置压缩格式,针对单个文件还好说,但是批量生成视频的时候,每一个都要设置格式, 体验不是很好,经过查询资料问题得到解决 最开始 ...
- MyEclipse,Eclipse注释规范模板
注释的作用:myeclipse中java文件头注释格式设置,最终可用于javadoc.exe生成API文档,同时提高了代码的可读性 设置方法: windows->preferences-> ...
- Hihocoder #1479 : 三等分 树形DP
三等分 描述 小Hi最近参加了一场比赛,这场比赛中小Hi被要求将一棵树拆成3份,使得每一份中所有节点的权值和相等. 比赛结束后,小Hi发现虽然大家得到的树几乎一模一样,但是每个人的方法都有所不同.于 ...
- 阳性比例 mysql CASE UNION ALL
阳性比例 mysql CASE UNION ALL SELECT t.*,t.type_0/all_ FROM ( SELECT FROM_UNIXTIME(create_time,'%Y-%m-%d ...
- 【LIS】Luogu P1020 导弹拦截
昨天晚上看蓝书,看到了LIS问题的优化解法. 是比O(n方)更快的解法,实际上是一个常数优化. 先讲一下朴素的解法: 一个集合a,a[i]是第i个元素.设dp[i]为以编号为i的元素结尾的最长不上升子 ...
- E20170602-ts
questionnaire n. 调查问卷; 调查表; アンケート不是英语 collection n. 征收; 收集,采集; 收藏品; 募捐; association n. 联想; 协会, ...
- bzoj 1651: [Usaco2006 Feb]Stall Reservations 专用牛棚【贪心+堆||差分】
这个题方法还挺多的,不过洛谷上要输出方案所以用堆最方便 先按起始时间从小到大排序. 我用的是greater重定义优先队列(小根堆).用pair存牛棚用完时间(first)和牛棚编号(second),每 ...
- Akka源码分析-Akka-Streams-GraphStage
上一篇博客中我们介绍了ActorMaterializer的一小部分源码,其实分析的还是非常简单的,只是初窥了Materializer最基本的初始化过程及其涉及的基本概念.我们知道在materializ ...
- NET 编程题
1.C#编写创建一个线程的代码 using System; using System.IO; using System.Threading ; class MyThread{ public int c ...
- excel 录入oracle 方法
http://blog.itpub.net/28602568/viewspace-1797410/ 1.方法1:外部表 1.将excel另存为.txt格式(2种txt 格式都可以),再传到数据库dir ...