.net core 1.1下的EntityFramework Code First
admin
2023-05-28 09:21:40
0

新建asp.net core项目,然后把.net core引用的类库升级到1.1,这时,需要手动在project.json下添加一个runtimes节点,如下:

"runtimes": {

  "win10-x64": {}

}

 同时在Nuget中添加下面三个类库(1.1版本):

Microsoft.EntityFrameworkCore.Design

Microsoft.EntityFrameworkCore.SqlServer

Microsoft.EntityFrameworkCore.Tools

 

接下来定义DbContext,用来生成数据库,代码如下:

using Microsoft.EntityFrameworkCore;
using System.Collections.Generic;
using System.ComponentModel.DataAnnotations;
 
namespace EntityFrameworkDemo.Model
{
    /// 
    /// 数据库对象
    /// 
    public class PermissionContext : DbContext
    {
        public PermissionContext(DbContextOptions opt) : base(opt)
        {
        }
        protected override void OnModelCreating(ModelBuilder modelBuilder)
        {
            //确定UserRole表中的两个字段是联合主键
            modelBuilder.Entity()
                .HasKey(u=>new { u.UserID,u.RoleID});
        }
        public DbSet Users
        { get; set; }
        public DbSet Roles
        { get; set; }
 
        public DbSet UserRoles
        { get; set; }
    }
    /// 
    /// 用户表
    /// 
    public class User
    {
        [Key]
        public int ID
        { get; set; }
        public string UserName
        { get; set; }
 
        public string Password
        { get; set; }
 
        public List UserRoles { get; set; }
    }
    /// 
    /// 角色表
    /// 
    public class Role
    {
        [Key]
        public int ID
        { get; set; }
        public string RoleName
        {
            get;set;
        }
        public List UserRoles { get; set; }
    }
    /// 
    /// 用户角色关系
    /// 
    public class UserRole
    {
      
        public int UserID
        { get; set; }
      
        public int RoleID
        { get; set; }
 
        public User User{ get; set; }
        public Role Role { get; set; }
    }
}


这时,需要在StartUp.cs中添加数据连字符串,来指导自动生成数据库时的服务器,数据库名等信息

public void ConfigureServices(IServiceCollection services)
{
    var connection = @"Server=.;Database=PermissionDb;Trusted_Connection=True;";
    services.AddDbContext(options => options.UseSqlServer(connection));
 
    services.AddMvc();
}


现在,先Build一下项目,用两个命令在程序包管理器控制台(vs的菜单“工具”-“NuGet包管理器”-“程序包管理器控制台”)中执行:

Add-Migration MyFirstMigration

用来生成命令,生成数据库和表的C#代码

Update-Database

执行生成的代码

在用Add-Migration MyFirstMigration时会报个错,在netcoreapp1.1中没有需要的项目配置文件(.json的),这时打开bin目录,会发现在netcoreapp1.1下会多一个win10-x64文件夹,这正是我们手工在project.json中添加的,打开这个文件夹,把里面对应的.json复制出来就可以(这里应该是Add-MigrationMyFirstMigration生成代码时,默认的寻找配置文件与我们手工添加runtimes的路径不一直导致)

 .net core 1.1下的EntityFramework Code First

复制完后再Add-Migration MyFirstMigration一次

会发现在项目中添加了一个文件夹Migrations,并在下面生成两个文件,这便是生成数据库所需的指令。

现在再执行Update-Database

.net core 1.1下的EntityFramework Code First

当执行成功后,用SQL Server的管理工具查看,生成的数据库,并且表中的表关系入下:

.net core 1.1下的EntityFramework Code First


相关内容

热门资讯

三星罢工危机暂解,加薪6.2%... 三星电子在最后关头与工会达成初步协议,避免了一场可能严重冲击全球内存芯片供应链的大规模罢工。对于正处...
马办与调查小组撕破脸,李德维称... 马英九指控基金会前执行长萧旭岑、王光慈破坏财政纪律,并指派基金会董事组成三人小组调查,但基金会数度指...
潮涌伊滨向“新”行 魏书生中学的“AI创想家”未来教室。伊滨宣供图钢制家具智能化生产场景。张若含 摄宁德时代洛阳基地。张...
河南尉氏县多人呕吐腹泻,当地成... 极目新闻记者 王鹏近日,河南开封尉氏县多位网友发视频称,当地有不少居民出现呕吐、腹泻的情况,视频画面...
全自动洗衣机应该咋清洗 全自动洗衣机应该咋清洗可以将洗衣机排水管拿下放在一个空水桶上,然后关闭进水阀门和前门,将三水壶用量的...
微波炉怎么清洗? 微波炉的外观清洁非常简单,平时勤用抹布擦拭就可以了。微波炉里面太脏,不需要用洗洁精擦洗,简单到家清洗...
秋季冰箱调到什么档位最合适 一般情况下秋季冰箱调到2~3档是最合适的,也就是说在这个季节冰箱的冷冻室温度需保持在-18℃以下,而...
冰箱档位1凉还是7凉 对于大多数的冰箱来说,温度从1档位到7档位是逐渐降低的,当然制冷效果也是逐渐地增强的,所以也就是说档...
冰箱保鲜的档位12345 哪个... 冰箱保鲜的档位通常表示温度的高低,数字越大,温度越低,制冷效果越好。因此,5 档通常是最冷的档位。然...
赖清德“5·20”讲话包装“台... 针对台湾地区领导人赖清德“5·20”发表的就职两周年讲话,台湾劳动党主席吴荣元接受港媒“中评社”访问...