MVC和EF中的 Model First 和 Code First
准备:先引入MVC和EF的dll包
*命令方法:打开工具——库程序包管理器——程序包管理器控制台,选择自己的项目
a) Install-Package EntityFramework -Version 6.1.1
b) Install-Package Microsoft.AspNet.Mvc -Version 5.2.2
一、Code First
模式是以代码先行,将Model层写好后反射数据库的方法,这里的数据库需要自己新建,并与model层的字段名完全对应。

实现的方法如下:
1.先新建一个实体类,取名Test(与数据库表名一致),添加字段
public class Test
{
public int Id { get; set; }
public string Name { get; set; }
}
2.建立一个Context类,取名TestContext,调用DbSet来反射数据库的内容
public DbSet<Test> Test { get; set; }
3.在controller层实现对model层数据的调用
private TestContext db = new TestContext();
public ActionResult Index()
{
var data = db.Test.ToList();
return View(data);
}
4.在View层中调用@Model.Id和@Model.Name。
5.在配置文件里添加数据库连接
<connectionStrings>
<add name="TestContext" connectionString="Data Source=.\SQLEXPRESS; user id=sa;password=sa;Initial Catalog=test1;Integrated Security=True" providerName="System.Data.SqlClient" />
</connectionStrings>
6.在数据库中建立一个Test表,加入Id和Name字段,即可运行测试。
二、Model First
模式是以数据库为基准来编写代码,这里需要先新建一个实体数据模型,根据这个模型将会自动生成数据库文件

1.新建数据模型,命名为model1,选择空模型
2.在自己建好的Model1.edmx文件页面中右键,新增,实体,填写实体信息。实体名称对应表名,创建键属性对应表的主键。
创建好后右键点击标量属性在实体模型中添加字段。

3.在自己的表上点击“根据模型生成数据库”

打开数据库即可看到自己刚刚所建的字段信息。调用数据库的方法百度。
利弊:
ModelFirst比较方便,但每次生成时会重新创建数据库,所以如果之前数据库中有数据的话会被清空。
MVC和EF中的 Model First 和 Code First的更多相关文章
- 1、MVC和EF中的 Model First 和 Code First
		准备:先引入MVC和EF的dll包 *命令方法:打开工具——库程序包管理器——程序包管理器控制台,选择自己的项目 a) Install-Package EntityFramework -Ver ... 
- 如何在ASP.NET MVC和EF中使用AngularJS
		(此文章同时发表在本人微信公众号"dotNET每日精华文章",欢迎右边二维码来关注.) AngularJS作为一个越来越流行的前端框架,在使用ASP.NET MVC和实体框架开发W ... 
- 1.【使用EF Code-First方式和Fluent API来探讨EF中的关系】
		原文链接:http://www.c-sharpcorner.com/UploadFile/3d39b4/relationship-in-entity-framework-using-code-firs ... 
- 2.EF中 Code-First 方式的数据库迁移
		原文链接:http://www.c-sharpcorner.com/UploadFile/3d39b4/code-first-migrations-with-entity-framework/ 系列目 ... 
- EF中 Code-First 方式的数据库迁移
		原文链接:http://www.c-sharpcorner.com/UploadFile/3d39b4/code-first-migrations-with-entity-framework/ 系列目 ... 
- ASP.NET MVC和EF集成AngularJS开发
		参考资料: 如何在ASP.NET MVC和EF中使用AngularJS AngularJS+ASP.NET MVC+SignalR实现消息推送 [AngularJs + ASP.NET MVC]使用A ... 
- easyui datagrid 禁止选中行    EF的增删改查(转载)   C# 获取用户IP地址(转载)  MVC EF 执行SQL语句(转载)    在EF中执行SQL语句(转载)  EF中使用SQL语句或存储过程  .net MVC使用Session验证用户登录  PowerDesigner 参照完整性约束(转载)
		easyui datagrid 禁止选中行 没有找到可以直接禁止的属性,但是找到两个间接禁止的方式. 方式一: //onClickRow: function (rowIndex, rowData) ... 
- ASP.NET MVC中默认Model Binder绑定Action参数为List、Dictionary等集合的实例
		在实际的ASP.NET mvc项目开发中,有时会遇到一个参数是一个List.Dictionary等集合类型的情况,默认的情况ASP.NET MVC框架是怎么为我们绑定ASP.NET MVC的Actio ... 
- ASP.NET MVC中对Model进行分步验证的解决方法
		原文:ASP.NET MVC中对Model进行分步验证的解决方法 在我之前的文章:ASP.NET MVC2.0结合WF4.0实现用户多步注册流程中将一个用户的注册分成了四步,而这四个步骤都是在完善一个 ... 
随机推荐
- vuejs模仿实现一个电影分享类网站
			前几天朋友发了一个电影分享类网站:http://dy.bingthink.top/ 感觉界面还挺好看的,所以打算用vuejs模仿写一个. 从后台转前端,要学习的东西挺多的,仅以此记录我的学习历程,闲的 ... 
- ubuntu中mysql版本升级到5.7
			0 前言 前几天图书馆说服务器(Ubuntu14.04)有安全漏洞,不按时修复会关停. 看了一下漏洞清单,主要是ssh和mysql的版本问题. 把mysql升级了一下,升到了5.7,升级之前还备份了数 ... 
- TOSCA自动化测试工具--识别元素唯一性的控件
			当Modules模块通过Scan识别出页面元素后,选择需要测试的对象,然后判断对象唯一性 
- Glide Picasso和Fresco的对比
			比较Picasso.Glide 和 Fresco 三种图片加载库 比较 Picasso 与 Glide 总体来说二者极为相似,有着近乎相同的 API 的使用风格,但 Glide 在缓存策略和加载 gi ... 
- C++与C混编
			C++与C混编 本案例通过实现一个简单的UDP服务器来说明C++与C的混合编程问题 C代码 通过C代码来对UDP服务器的创建,监听进行封装 udp.c文件 #include <sys/types ... 
- Hbase环境安装
			说明: (Hbase依赖于HDFS和zookeeper) 参考我的博客: https://www.cnblogs.com/654wangzai321/p/8603498.html https://ww ... 
- python替换一个文件里面的特定内容
			f = open("1.txt", "r", encoding="utf-8") f_new = open("2.txt" ... 
- CF1157D N Problems During K Days(简单构造)
			题目 题目 原数据是水成啥样了,\(<\longrightarrow <=,>=\longrightarrow <=,\)这也能过 被\(hack\)后身败名裂 做法 简单的贪 ... 
- Send2MyKindle使用说明文档
			软件下载地址为:Send2MyKindle 功能简介 该软件主要功能为在Windows下将Kindle电子书发送到亚马逊中国网站注册的Kindle账户.整个软件界面如下图所示: 使用步骤 使用前的准备 ... 
- mysql创建账号
			1.创建账号1)只读账号GRANT USAGE ON *.* TO 'testgao_r'@'192.168.1.1' IDENTIFIED BY 'password' WITH MAX_QUERIE ... 
