Entity Framework 学习笔记(2)
Entity Framework最主要的东西,就是自己创建的、继承于DbContext的类
:
/// <summary>
/// Context相当于一个数据库
/// </summary>
public class MusicContext : DbContext
{
//base("LocalDB")表示要用到config文件中的名为“LcoalDB”的连接字符串
public MusicContext() : base("LocalDB")
{
} //DbSet相当于数据表
public DbSet<Album> Albums { get; set; }
}
当然,我们的数据表定义类也很简单,如下:
/// <summary>
/// 专辑
/// </summary>
public class Album
{
public int AlbumId { get; set; }
public string Title { get; set; }
public decimal Price { get; set; }
}
对应的实际数据表定义为:

可以很容易看到,int和decimal都很正常,string被翻译为nvarchar(MAX)
很多时候我们并不需要让一个纯文本字段定义到nvarchar(MAX),大多数用的是一个实际的值,比如nvarchar(50)。
想在Entity Framework中去这样实现,就得给字段加入特性(Attribute):
需要添加两个命名空间:
using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;
/// <summary>
/// 专辑(Table表示要为创建的数据表手动设置表名称)
/// </summary>
[Table(name: "MyTable")]
public class Album
{
public int AlbumId { get; set; } /// <summary>
/// StringLength可以设定最大长度
/// </summary>
[StringLength(50)]
public string Title { get; set; } [Required]
public decimal Price { get; set; }
}
这时如果我们运行程序,就会报错
:

意思就是说:你程序中的表定义和数据库中的表定义不一致
(肯定不一致啊,我们都改定义了)
这个时候,我们就需要进行一组操作,将程序中的表定义,同步到数据库中去
:
- 打开Package Manager Console
- 输入Enable-Migrations,开启数据库迁移

(如果项目中有多个DbContext对象,则这里会报错,相应的解决方法就是指定DbContext的类的包括命名空间的全名:Enable-Migrations –ContextTypeName 全名)
(如果要让Entity Framework帮你自动将改动实施到目标数据库,则可以再添加一个选项 –EnableAutomaticMigrations,所以这个例子中比较好的写法就是:Enable-Migrations –ContextTypeName NormalTest.MusicContext –EnableAutomaticMigrations) - 图中的内容表示已经创建数据库迁移组件,Entity Framework在项目中添加了一些文件,可以在Solution Explorer中看到
- 这个时候呢,我们就可以继续输入指令Update-Database将目标数据库进行更新
(这里可以使用Update-Database –Scirpt选项来显示运行了哪些改动)。不过呢…又报错
意思是我们没有开启–EnableAutomaticMigrations这个选项。这里我们有两个方法来开启,一个是直接输入Enable-Migrations -EnableAutomaticMigrations -Force;另一个则是打开Entity Framework为我们刚刚创建好的Configuration.cs文件
把AutomaticMigrationsEnabled = false这个值改成true。 - 开启这个选项,我们再次输入Update-Database,还是报错


这个错误是说,你将要进行的改动会对你目前的数据造成损失(把无限长的字符串把长度变为50肯定会造成损失),所以我们没有你的授权就不干!好吧,既然你没授权,我们就给你授权!
授权的方式有两种,一个是使用Update-Database –Force来强行进行修改;另一个则是在刚才的Configuration.cs文件中再添加一句base.AutomaticMigrationDataLossAllowed = true;
- 好了,让我们再执行一次Update-Database


大功告成! - 让我们打开数据库表定义看看

表名变成了MyTable,并且Title字段有了最长限定

以上就是使用Entity Framework的Code First模式所进行的数据库更新,虽然繁琐,但是毕竟就是这么一个流程
PS.如果我们在最后更新数据库的时候,输入Update-Database –Script,VS会自动打开一个SQL编辑窗口,里面有自动升成的更新脚本,当然这个时候脚本还没有执行呢!!还得手动执行一次!!

Entity Framework 学习笔记(2)的更多相关文章
- Entity Framework学习笔记
原文地址:http://www.cnblogs.com/frankofgdc/p/3600090.html Entity Framework学习笔记——错误汇总 之前的小项目做完了,到了总结经验和 ...
- ADO.NET Entity Framework学习笔记(3)ObjectContext
ADO.NET Entity Framework学习笔记(3)ObjectContext对象[转] 说明 ObjectContext提供了管理数据的功能 Context操作数据 AddObject ...
- Entity Framework学习笔记——错误汇总
之前的小项目做完了,到了总结经验和更新学习笔记的时间了.开始正题之前先啰嗦一下,对之前的学习目标进行一个调整:“根据代码生成表”与“生成数据库脚本和变更脚本”合并为“Code First模式日常使用篇 ...
- Entity Framework学习笔记——记一个错误解决方式及思路
继续之前设定的学习目标前,先来一篇小小的外篇.按照第一篇里的配置方式配置好的工程前两天还能正常工作,昨天却突然无法通过Add-Migration命令进行数据库的升级.错误信息如下: System.Da ...
- Entity Framework学习笔记——配置EF
初次使用Entity Framework(以下简称EF),为了避免很快忘记,决定开日志记录学习过程和遇到的问题.因为项目比较小,只会用到EF的一些基本功能,因此先在此处制定一个学习目标:1. 配置EF ...
- Entity Framework学习笔记(四)----Linq查询(1)
请注明转载地址:http://www.cnblogs.com/arhat 从本章开始,老魏就介绍一下Entity Framework使用Linq来查询数据,也就是Linq To Entity.其实在E ...
- Entity Framework学习笔记(三)----CRUD(2)
请注明转载地址:http://www.cnblogs.com/arhat 昨天晚上老魏配的机器终于到了,可是拿回来之后什么都组装好了,唯独差一个非常重要的组件"电源线",老魏那个汗 ...
- Entity Framework学习笔记(二)----CRUD(1)
请注明转载地址:http://www.cnblogs.com/arhat 这篇文章老魏和大家分享一下Entity Framework的CRUD操作,在这之前呢,老魏先说一下老魏对EF的一个整体的认识, ...
- Entity Framework学习笔记(一)
请注明转载地址:http://www.cnblogs.com/arhat 哈哈!老魏回来了,4月份的内容开始更新了,由于3月份时间都在做项目,没有时间写了,那么4月份老魏会尽可能的多写点东西的.那么4 ...
随机推荐
- 【新闻】超灵敏MRI技术:照亮人体肺部
人口健康直接影响到一个国家的经济发展和社会进步.据我国2013年发布的肿瘤发病率统计年报表明,肺癌是我国目前首位恶性肿瘤,是癌症死亡的头号杀手,目前城市中每4名死亡的癌症患者中,约有1名是肺癌.如何开 ...
- 【不积跬步,无以致千里】Linux下启动Oracle服务和监听程序
oracle数据库是重量级的,其管理非常复杂,将其在linux平台上的启动和关闭步骤整理一下. 安装完毕oracle以后,需要创建oracle系统用户,并在/home/oracle下面的.bash_p ...
- postfix 不记录日志的问题解决方法
国内私募机构九鼎控股打造APP,来就送 20元现金领取地址:http://jdb.jiudingcapital.com/phone.html内部邀请码:C8E245J (不写邀请码,没有现金送)国内私 ...
- virtualbox 创建com对象失败
其实这个错误是因为VirtualBox不兼容Win7引起的,只要把VirtualBox的兼容模式改为出Win7以外的就行了.. 右键VirtualBox的桌面快捷方式,选择属性,选到兼容性选项卡,勾选 ...
- [置顶] 最小生成树Prim算法
二话不说直接贴代码 原图传送门:http://www.tyut.edu.cn/kecheng1/site01/suanfayanshi/minispantree.asp 但是上面展现的是克鲁斯卡尔算法 ...
- ORACLE 毫秒与日期的相互转换
毫秒转换为日期 SELECT TO_CHAR(1406538765000 / (1000 * 60 * 60 * 24) + TO_DATE('1970-01-01 08:00:00', 'YYYY- ...
- Android应用插件式开发解决方法[转]
一.现实需求描述 一般的,一个Android应用在开发到了一定阶段以后,功能模块将会越来越多,APK安装包也越来越大,用户在使用过程中也没有办法选择性的加载自己需要的功能模块.此时可能就需要考虑如何分 ...
- 分享SVN的钩子代码[借鉴学习]pre-commit-post 钩子
#/bin/bash REPOS=$1 TXN=$2 export HOME=/ export PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/us ...
- 一个响应式数据库框架SQLBrite,完美解决数据库和UI的同步更新!
相信小伙伴们在开发中或多或少都可能遇到过这样的问题:打开一个应用后,为了快速响应,先将数据库中的数据呈现给用户,然后再去网络上请求数据,请求成功之后将数据缓存至数据库,同时更新UI,但是我们经常会这样 ...
- NGINX server配置中if的用法
server的配置以php为例,如下: 1 server{ 2 root /var/webproject/www/mytools-php; 3 index index.html index.php; ...
