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阵营人士,少少多多总喜欢通过对 ...
随机推荐
- FunctionGraph无缝集成Express应用
Express APP 作为一个Node.js开发者,相信大家都可能会使用Express框架,无论是构建后端服务,或是搭建一个前端的开发态服务器,Express都是一个很流行的选择.构建Express ...
- ios打地鼠游戏源代码
打地鼠游戏源代码,游戏是一款多关卡基于cocos2d的iPad打地鼠游戏源代码,这也是一款高质量的打地鼠游戏源代码,能够拥有逐步上升的关卡的设置,大家能够在关卡时设置一些商业化的模式来盈利的,很完美的 ...
- png图片解码
PNG.可移植网络图形格式(Portable Network Graphic Format,PNG)名称来源于非官方的"PNG's Not GIF",是一种位图文件(bitmap ...
- Codeforces Round #313 B. Gerald is into Art(简单题)
B. Gerald is into Art time limit per test 2 seconds memory limit per test 256 megabytes input standa ...
- Redis内存使用达到maxmemory设定值后玩家数据无法写入解决 Redis数据“丢失”问题
Redis数据“丢失”问题 - CSDN博客 https://blog.csdn.net/real_myth/article/details/52582739 Redis内存使用达到maxmemory ...
- 在js中取选中的radio值
在js中取选中的radio值 <input type="radio" name="address" value="0" /> & ...
- MFC ListControl技巧汇总
转自:http://hi.baidu.com/qi_xian/blog/item/1971aa22da89ada24723e856.html 以下未经说明,listctrl默认view 风格为repo ...
- Java中的经典算法之冒泡排序
原理:比较两个相邻的元素,将值大的元素交换至右端. 思路:依次比较相邻的两个数,将小数放在前面,大数放在后面.即在第一趟:首先比较第1个和第2个数,将小数放前,大数放后.然后比较第2个数和第3个数,将 ...
- TI BLE:读本机地址
uint8 ownAddress[B_ADDR_LEN]; //B_ADDR_LEN=6GAPRole_GetParameter(GAPROLE_BD_ADDR, ownAddress); #def ...
- DNS域名记录
DNS域名记录 DNS数据库 在DNS的解析过程中用到域名的解析资源的记录,这个解析记录在DNS当中称为DNS数据库. 这个数据库又分为正解和反解,正解就是从主机名到ip的过程,反解就是从ip反响解析 ...