EF1:MVC/EF(Entity Framewok) /First Migrations
1. 概念
Entity Framework: ADO.NET Entity Framework 是微软以 ADO.NET 为基础所发展出来的对象关系对应 (O/R Mapping) 解决方案.(此处只当理解为.NET 特色的数据库应用方案(O/R mapping),如hibernate, 此处暂且不做深入,有待日后补充学习)。简单来说就是微软帮你连接了数据库的是一个实体框架,让你操作起来比较方便,不用过多去写SQLhelper并能和linq语句lamda表达式等结合起来,提高开发效率。
First Migrations: .Net 数据库迁移工具,应用于结合EF进行数据库管理应用。
2.通过项目运行数据库
1.数据库连接配置。项目 web.config中添加数据库连接相关:

<connectionStrings>
<add name="DefaultConnection"
connectionString="Data Source=(LocalDb)\v11.0;Initial Catalog=aspnet-MvcMovie-2012213181139;Integrated Security=true"
providerName="System.Data.SqlClient"
/>
<add name="MovieDBContext"
connectionString="Data Source=(LocalDB)\v11.0;AttachDbFilename=|DataDirectory|\Movies.mdf;Integrated Security=True"
providerName="System.Data.SqlClient"
/>
</connectionStrings>

2.先构造实体类和上下文关联,如3中类代码。
3.通过项目代码运行private PortalContext db = new PortalContext();自动生成数据库。常见初学教程mvc
通过control 生成示例:
微软 MVC 教程 通过control 模板生成Movie 增删改查相关操作。
注:为了继续学习3中first migrations数据迁移,删除App_data中数据库文件*.mdf.
3. First migrations应用举例
- 生出数据库实体关联
需要先构造实体类(对应表)和上下文关联,代码如下:


using System;
using System.Collections.Generic;
using System.Data.Entity;
using System.Linq;
using System.Web; namespace MVCEFTest.Models
{
public class Movie
{
public int ID { set; get; }
public String Name { set; get; }
public Double Price { set; get; }
public int Level { set; get; }
} public class People
{
public int ID { set; get; }
public String Name { set; get; }
public int Year { set; get; }
} public class PortalContext : DbContext
{
//静态构造函数中,设置了当数据库模型发生改变时,则删除当前数据库,重建新的数据库。
//static PortalContext()
//{
// Database.SetInitializer(new DropCreateDatabaseIfModelChanges<PortalContext>());
//} public DbSet<Movie> Movies { get; set; }
public DbSet<People> Peoples { get; set; }
} }


点击“工具/库程序包管理器/程序包管理控制台”,打开程序包管理控制台:
如果未添加 Entity Framework ,先安装Entity Framework:
PM> Install-Package EntityFramework
执行
PM> Enable-Migrations -EnableAutomaticMigrations
已为项目 MVCEFTest 启用 Code First 迁移。
执行成功,项目中添加了Migrations文件夹,并生成类文件Configuration.cs。代码如下namespace MVCEFTest.Migrations

{
using System;
using System.Data.Entity;
using System.Data.Entity.Migrations;
using System.Linq; internal sealed class Configuration : DbMigrationsConfiguration<MVCEFTest.Models.PortalContext>
{
public Configuration()
{
AutomaticMigrationsEnabled = true;
} protected override void Seed(MVCEFTest.Models.PortalContext context)
{
// This method will be called after migrating to the latest version. // You can use the DbSet<T>.AddOrUpdate() helper extension method
// to avoid creating duplicate seed data. E.g.
//
// context.People.AddOrUpdate(
// p => p.FullName,
// new Person { FullName = "Andrew Peters" },
// new Person { FullName = "Brice Lambson" },
// new Person { FullName = "Rowan Miller" }
// );
//
} } }

seed为初始化执行代码,如上可通过 context.People.AddOrUpdate 添加数据。
- 数据数据库实体(O/R mapping)修改
PM> Add-Migration initial
正在为迁移“initial”搭建基架。
此迁移文件的设计器代码包含当前 Code First 模型的快照。在下一次搭建迁移基架时,将使用此快照计算对模型的更改。如果对要包含在此迁移中的模型进行其他更改,则您可通过再次运行“Add-Migration 201601120840091_initial”重新搭建基架。
PM>
在Migrations文件夹中生成 201601120840091_initial.cs。
- 数据库同步(数据迁移)

PM> Update-Database -Verbose
Using StartUp project 'MVCEFTest'.
Using NuGet project 'MVCEFTest'.
指定“-Verbose”标记以查看应用于目标数据库的 SQL 语句。
目标数据库为: “MVCEFTest.Models.PortalContext”(数据源: (localdb)\v11.0,提供程序: System.Data.SqlClient,来源: Convention)。
无任何待定的基于代码的迁移。
正在运行seed方法。

4. 错误记录
应用本地sql server 应用实例,生成第一次完成后,删除mdf,重新生成有时会造成,形式各种的数据库链接错误。
大多如,connectstring 错误,*.mdf找不到等,因本地备份遗留或者名称不对应等。可通过“视图/sql server 管理器”删除/增加(如有遗留请删除,如未有重新请添加)操作可解决,已验证:
打开vs2013的sql对象资源管理器,
删除(LocalDb)\v11.0服务器下面已经存在的数据库
(LocalDb)\v11.0如果不存在,就先添加,,再删除它下面的数据库。
EF1:MVC/EF(Entity Framewok) /First Migrations的更多相关文章
- 【MVC 1】MVC+EF实体框架—原理解析
导读:在之前,我们学过了三层框架,即:UI.BLL.DAL.我们将页面显示.逻辑处理和数据访问进行分层,避免了一层.两层的混乱.而后,我们又在经典三层的基础上,应用设计模式:外观.抽象工厂+反射,使得 ...
- ASP.NET MVC with Entity Framework and CSS一书翻译系列文章之第一章:创建基本的MVC Web站点
在这一章中,我们将学习如何使用基架快速搭建和运行一个简单的Microsoft ASP.NET MVC Web站点.在我们马上投入学习和编码之前,我们首先了解一些有关ASP.NET MVC和Entity ...
- 【MVC 2】MVC+EF框架结构实例:注册ID号验证
导读:本篇博客,将通过一个实例,详细介绍MVC+EF的应用.原理性的东西或者说是进一步的解耦和,请看博客: [框架结构 3]MVC+EF实体框架-原理解析.在这里,仅用MVC框架和一个EF生成的Mod ...
- ASP.NET MVC with Entity Framework and CSS一书翻译系列文章之第六章:管理产品图片——多对多关系(上篇)
在这章中,我们将学习如何创建一个管理图片的新实体,如何使用HTML表单上传图片文件,并使用多对多关系将它们和产品关联起来,如何将图片存储在文件系统中.在这章中,我们还会学习更加复杂的异常处理,如何向模 ...
- MVC+EF 序列化类型为“System.Data.Entity.DynamicProxies.__的对象时检测到循环引用
用MVC+EF做简单查询时,返回json格式数据出现问题 原代码: public ActionResult JSon({ NorthwindEntities db = new NorthwindEnt ...
- APS.NET MVC + EF (02)---ADO.NET Entity FrameWork
2.1 Entity Framework简介 Ado.net Entity Framework 是Microsoft推出的ORM框架. 2.1.1 什么是ORM 对象关系映射(Object Relat ...
- 用 MVC 5 的 EF6 Code First 入门 系列:MVC程序中实体框架的Code First迁移和部署
用 MVC 5 的 EF6 Code First 入门 系列:MVC程序中实体框架的Code First迁移和部署 这是微软官方SignalR 2.0教程Getting Started with En ...
- 使用ASP.NET Core MVC 和 Entity Framework Core 开发一个CRUD(增删改查)的应用程序
使用ASP.NET Core MVC 和 Entity Framework Core 开发一个CRUD(增删改查)的应用程序 不定时更新翻译系列,此系列更新毫无时间规律,文笔菜翻译菜求各位看官老爷们轻 ...
- ASP.NET Core MVC+EF Core从开发到部署
笔记本电脑装了双系统(Windows 10和Ubuntu16.04)快半年了,平时有时间就喜欢切换到Ubuntu系统下耍耍Linux,熟悉熟悉Linux命令.Shell脚本以及Linux下的各种应用的 ...
随机推荐
- 大数据学习——hadoop安装
上传centOS6.7-hadoop-2.6.4.tar.gz 解压 tar -zxvf centOS6.7-hadoop-2.6.4.tar.gz hadoop相关修改配置 1 修改 /root/a ...
- 安装SecureCRT注册
注册方法 1.首先运行压缩包中的安装程序进行安装原版程序!2.安装完成后记得先不要运行程序!3.复制压缩包中的keygen.exe程序到安装目录!4.运行keygen.exe,点击Patch按钮对源程 ...
- python和shell获取命令行参数的区别
一.命令行参数的取得对于一些功能性的脚本来说非常有用,不至于将功能写死在脚本中. shell的命令行参数直接用 $ 1,$2 等就可以直接获取 其中 $1 表示 第二个参数,即命令行的第一个参数,因为 ...
- .net中的协变和逆变
百度:委托中的协变和逆变. 百度:.net中的协变和逆变. 协变是从子类转为父类. 逆变是从父类到子类. 这样理解不一定严谨或者正确.需要具体看代码研究.
- ORACLE金额转换成英文大写的函数
用法如下:get_capital_money(Currency, Money) Currency: 货币或货币描述,将放在英文大写的前面: Money:金额.支持两位小数点.如果需要更多的小数点,请自 ...
- [NOIP2000] 提高组 洛谷P1018 乘积最大
题目描述 今年是国际数学联盟确定的“2000――世界数学年”,又恰逢我国著名数学家华罗庚先生诞辰90周年.在华罗庚先生的家乡江苏金坛,组织了一场别开生面的数学智力竞赛的活动,你的一个好朋友XZ也有幸得 ...
- APP后端处理视频的方案
在当前的app应用中,到处都能看到视频的身影,例如,在社交类的app上,用户可以拍摄属于自己的小视频,并发布到相应得栏目,增加和好友们互动的机会. 后台常见的视频处理有以下几种: · ...
- Sublime3 Preference, Settings-User
{"font_face": "Consolas","font_size": 15,"ignored_packages": ...
- win8,win10里面内置的IE浏览器网银无法输入密码
win8,win10里面内置的IE浏览器网银无法输入密码,安装控件也没效果,部分网银直接导致IE崩溃,只需要简单设置即可解决. 方法/步骤 1 打开IE浏览器,点击右上角的小齿轮图标,在下拉菜单中 ...
- Unity 3D 中动态字体的创建
原创不易,转载请注明转自: http://blog.csdn.net/u012413679/article/details/26232453 ---- kosion 1.载入NGUI插件包,载入完毕后 ...