zoukankan      html  css  js  c++  java
  • .Net Core建站(2):EF Core+CodeFirst数据库迁移

    上一篇的话,说了下怎么使用EF7 实现 CodeFirst去生成数据库,

    其实还有好多问题的,这次一点一点的解决吧,都挺简单,不过零零散散的,,

    1.读取配置文件,获得链接字符串

    2.使用数据库进行增删查改

    3.实体类更新后,数据库也更新

    一、读取配置文件,获得链接字符串

    上一篇我们的链接字符串是这样写的

    直接写在程序里面是非常非常不好的行为,所以我很简单粗暴的丢到appsettings.json这个配置文件里面去了,,

    1 {
    2   "Logging": {
    3     "IncludeScopes": true,
    4     "LogLevel": {
    5       "Default": "Warning"
    6     }
    7   },
    8   "ConStr": "server=.;Database=DBCodeFirst;uid=sa;pwd=12346"
    9 }

    接下来,要愁的是怎么把配置读出来,而且,既然是配置文件,肯定整个项目都要用上,肯定是要封装起来的,

    网上也找了很多啊,各种各样的, 有些大佬还可以直接读取成一个对象,这里我不搞那些骚操作啊,,,emmm,不会告诉你们我看不懂的

    走最简单的,键值对,就像以前读取webconfig文件一样,

    首先需要引用三个包,直接右键编辑commom.csproj

    1     <PackageReference Include="Microsoft.Extensions.Configuration" Version="2.0.0" />
    2     <PackageReference Include="Microsoft.Extensions.DependencyInjection" Version="2.0.0" />
    3     <PackageReference Include="Microsoft.Extensions.Options.ConfigurationExtensions" Version="2.0.0" />

    然后新建一个类Config

     1 using Microsoft.Extensions.Configuration;
     2 using Microsoft.Extensions.DependencyInjection;
     3 using Microsoft.Extensions.Options;
     4 using System;
     5 using System.Diagnostics;
     6 
     7 namespace Common
     8 {
     9     /// <summary>
    10     /// 配置类
    11     /// </summary>
    12     public class Config
    13     {
    14         /// <summary>
    15         /// 所有的配置数据
    16         /// </summary>
    17         private static IConfigurationRoot Configuration { get; set; }
    18 
    19         /// <summary>
    20         /// 获得数据
    21         /// </summary>
    22         /// <param name="_Configuration"></param>
    23         public static void SetConfig(IConfigurationRoot _Configuration)
    24         {
    25             Configuration = _Configuration;
    26         }
    27 
    28         /// <summary>
    29         /// 返回对应键的值
    30         /// </summary>
    31         /// <typeparam name="T"></typeparam>
    32         /// <param name="key"></param>
    33         /// <param name="def">默认值</param>
    34         /// <returns></returns>
    35         public static T GetVal<T>(string key, T def = default(T))
    36         {
    37             try
    38             {
    39                 def = (T)Convert.ChangeType(Configuration.GetSection(key).Value, typeof(T));
    40             }
    41             catch (Exception e)
    42             {
    43                 Debug.WriteLine(e.Message);
    44             }
    45             return def;
    46         }
    47 
    48     }
    49 
    50 }

    然后还要进行一下配置,在Startup.cs文件的Startup方法改造一下:

    1         public Startup(IConfiguration configuration)
    2         {
    3             IConfigurationRoot config = new ConfigurationBuilder()
    4                   .SetBasePath(Directory.GetCurrentDirectory())
    5                   .AddJsonFile("appsettings.json", optional: true, reloadOnChange: true)
    6                   .Build();
    7 
    8             Config.SetConfig(config);
    9         }

    使用方法很简单的,一句话就好:

    1         // 数据库连接字符串
    2         string conStr = Config.GetVal<string>("ConStr");

    因为现在的配置文件是json格式,所以,层级结构是肯定会有的,比如说,我现在要读取Logging下的IncludeScopes值,可以这样写:

    1          string IncludeScopes = Config.GetVal<string>("Logging:IncludeScopes");

    以此类推,,,这样肯定没其他大佬们直接读取成对象来得快,不过好在简单易懂,以后等我学会了那种高大上的方法再来分享,,现在先就酱紫用着,,

    二、使用数据库进行增删查改

    这一段主要是吐槽,,

    以前我们使用EF,不管是DBFirst还是CodeFirst,亦或者ModelFirst,要使用数据库都是很简单粗暴的new一个上下文对象

    1    // 数据库上下文
    2    var DB=new DBCodeFirst();

    然鹅!!!!!!!当我用CodeFirst把数据库生成以后,喜滋滋的跑过去加一条测试数据,

    1         public IActionResult Index()
    2         {
    3             DBCodeFirst db = new DBCodeFirst();
    4             db.DT_User.Add(new DT_User { UserName = "嘿嘿" });
    5             var count = db.SaveChanges();7             return View();
    8 
    9         }

    他丫的给我报错,,,

    翻译过来就是这个,,

    没有数据库提供商已为这个DbContext。
    一个供应商可以通过重写dbcontext.onconfiguring方法或使用adddbcontext对应用服务提供商配置。
    如果adddbcontext使用,并确保你的DbContext类型构造函数接受dbcontextoptions < tcontext >对象并将其传递给DbContext基构造函数。”

     反正我是没看懂的,,,永远不知道当时我的心情是多么的难受,

    又是一阵百度啊,可算是被我找到解决方法了,,,得这样写:

    讲真,我还没接触到依赖注入,所以这段代码看的是有点懵逼的,

    好像关联的是Startup这个类里面的ConfigureServices方法,哪位大佬有兴致的话可以给我留言讲讲,感激不尽

    不过好歹是可以用数据库了,,下一步是搭一个三层,,一筹莫展ing,,,

    以前是可以直接new上下文,现在不行了,还不知道这个依赖注入能不能在其他层使用,,

    等我把三层整出来之后,再写出来分享吧,,估计是下一篇了

    三.实体类更新后,数据库也更新

    这个的话首先回顾上一篇啊,

    在上一篇里面用了两个命令来生成数据库(DBLog我改成Init了,,这个随意,,)

     Add-Migration Init
      Update-DataBase Init

    如果在上下文中加了实体类或者修改了实体类字段,我们肯定是要更新数据库的,

    这个时候,我们在已经生成数据库和Migrations文件夹的前提下,继续使用上面的两个命令

    不过这个时候要稍稍改动:

    Add-Migration UpData
    和
    Update-DataBase UpData

    记得每次使用的时候,最后一个参数名称千万不能一样

    就像我第一次使用的名称是Init 第一次更新数据库的时候,使用的是UpData

    以后肯定还会有更多的更新,每次都不能一样,比如:UpData01、UpData02、UpData03、...

    同时Migrations文档会对应的增加内容

    数据库自动生成的__EFMigrationsHistory表中也会有我们的数据库迁移记录

    emmm,差不多就这些吧,,,

    我还得想办法把三层整出来,,,,脸滚键盘.gif

  • 相关阅读:
    /bin/bash^M:损坏的解释器: 没有那个文件或目录
    QT槽函数处理线程
    Strategy策略模式
    Proxy代理模式
    Ubuntu系统修改BIOS时间问题
    Ubuntu下安装Goldendict(翻译软件)
    自定义QMenu
    C connect实现Timeout效果(Windows)
    059 Python计算生态概览
    058 程序设计方法学小结
  • 原文地址:https://www.cnblogs.com/Onlooker/p/8097588.html
Copyright © 2011-2022 走看看