上期回顾:Entity Framework 学习笔记(1)


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; }
        }

这时如果我们运行程序,就会报错

意思就是说:你程序中的表定义和数据库中的表定义不一致(肯定不一致啊,我们都改定义了)

这个时候,我们就需要进行一组操作,将程序中的表定义,同步到数据库中去

  1. 打开Package Manager Console

  2. 输入Enable-Migrations,开启数据库迁移

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

    意思是我们没有开启–EnableAutomaticMigrations这个选项。这里我们有两个方法来开启,一个是直接输入Enable-Migrations -EnableAutomaticMigrations -Force;另一个则是打开Entity Framework为我们刚刚创建好的Configuration.cs文件

    把AutomaticMigrationsEnabled = false这个值改成true。
  5. 开启这个选项,我们再次输入Update-Database,还是报错

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

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

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

以上就是使用Entity Framework的Code First模式所进行的数据库更新,虽然繁琐,但是毕竟就是这么一个流程

PS.如果我们在最后更新数据库的时候,输入Update-Database –Script,VS会自动打开一个SQL编辑窗口,里面有自动升成的更新脚本,当然这个时候脚本还没有执行呢!!还得手动执行一次!!

Entity Framework 学习笔记(2)的更多相关文章

  1. Entity Framework学习笔记

    原文地址:http://www.cnblogs.com/frankofgdc/p/3600090.html Entity Framework学习笔记——错误汇总   之前的小项目做完了,到了总结经验和 ...

  2. Entity Framework学习笔记——错误汇总

    之前的小项目做完了,到了总结经验和更新学习笔记的时间了.开始正题之前先啰嗦一下,对之前的学习目标进行一个调整:“根据代码生成表”与“生成数据库脚本和变更脚本”合并为“Code First模式日常使用篇 ...

  3. Entity Framework学习笔记——记一个错误解决方式及思路

    继续之前设定的学习目标前,先来一篇小小的外篇.按照第一篇里的配置方式配置好的工程前两天还能正常工作,昨天却突然无法通过Add-Migration命令进行数据库的升级.错误信息如下: System.Da ...

  4. Entity Framework学习笔记——配置EF

    初次使用Entity Framework(以下简称EF),为了避免很快忘记,决定开日志记录学习过程和遇到的问题.因为项目比较小,只会用到EF的一些基本功能,因此先在此处制定一个学习目标:1. 配置EF ...

  5. Entity Framework学习笔记(四)----Linq查询(1)

    请注明转载地址:http://www.cnblogs.com/arhat 从本章开始,老魏就介绍一下Entity Framework使用Linq来查询数据,也就是Linq To Entity.其实在E ...

  6. Entity Framework学习笔记(三)----CRUD(2)

    请注明转载地址:http://www.cnblogs.com/arhat 昨天晚上老魏配的机器终于到了,可是拿回来之后什么都组装好了,唯独差一个非常重要的组件"电源线",老魏那个汗 ...

  7. Entity Framework学习笔记(二)----CRUD(1)

    请注明转载地址:http://www.cnblogs.com/arhat 这篇文章老魏和大家分享一下Entity Framework的CRUD操作,在这之前呢,老魏先说一下老魏对EF的一个整体的认识, ...

  8. Entity Framework学习笔记(一)

    请注明转载地址:http://www.cnblogs.com/arhat 哈哈!老魏回来了,4月份的内容开始更新了,由于3月份时间都在做项目,没有时间写了,那么4月份老魏会尽可能的多写点东西的.那么4 ...

  9. Entity Framework学习笔记(五)----Linq查询(2)---贪婪加载

    请注明转载地址:http://www.cnblogs.com/arhat 在上一章中,我们使用了Linq对Entity Framework进行了一个查询,但是通过学习我们却发现了懒加载给我来的性能上的 ...

随机推荐

  1. Flapper Bird的学习笔记(二)

    因为有一个超屌的梦想,所以就绝不会做一个孬种的追梦人! 本章节主要目的: 实现小鸟的飞行. 实现管道的随机出现. 实现相机跟随. 上次主要是场景的布置,这节全力拿下代码. 1.小鸟飞行(一种制作2D动 ...

  2. 拒绝了对对象 &#39;XXX&#39; (数据库 &#39;XXX&#39;,架构 &#39;dbo&#39;)的 SELECT 权限

    2010-04-17 23:16 在IIS里测试ASP.NET网站时会遇到这样的问题(ASP.NET+SQL2005)我自己的解决方法是这样的: 1.打开SQL2005管理界面(没有安装SQLServ ...

  3. 获取客户端IP

    function getIP(){ $ip = ""; if (getenv("HTTP_CLIENT_IP") && strcasecmp(g ...

  4. pt-online-schema-change 实例

    pt-pmp (http://www.cnblogs.com/ivictor/p/6012183.html) pt-online-schema-change (http://blog.csdn.net ...

  5. CoreAnimation动画(CALayer动画)

    #pragma mark - CABasicAnimation动画 - (IBAction)basicAnimation:(UIButton *)sender { // 1.创建动画对象 CABasi ...

  6. Java内存管理和垃圾回收

    笔记,深入理解java虚拟机 Java运行时内存区域 程序计数器,线程独占,当前线程所执行的字节码的行号指示器,每个线程需要记录下执行到哪儿了,下次调度的时候可以继续执行,这个区是唯一不会发生oom的 ...

  7. 转:python webdriver API 之分页处理

    对于 web 页面上的分页功能,我们一般做做以下操作:  获取总页数  翻页操作(上一页,下一页) 对于有些分页功能提供上一页,下一页按钮,以及可以输入具体页面数跳转功能不在本例的讨论范围. .. ...

  8. CUBRID学习笔记 14 删除主键错误

    发生这样的问题.其实和别的数据库基本原因差不多.  就是外键冲突. 看看有没有外键引用这个表的主键. 然后删除外键. 就可以了 SELECT class_name FROM db_index WHER ...

  9. SecureCRT显示中文和语法高亮

    因为默认情况下,SecureCRT不能显示语法高亮特性,整个界面颜色单一,看起来不爽,也没有效率,所有通过设置一下语法高亮还是很有必要的, 默认字体也看着不是很清晰,还是更改为我比较喜欢的Courie ...

  10. CSS的基本操作

    <html> <!-- . 给整个页面填一个一个背景 . 给em添加一个样式样倾斜效果消失 . 改变第一层UL的样式为蓝色,16px . 改变第二层的UL的样式为红色 14px . ...