iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >.net core 1.1下的EntityFramework Code First
  • 332
分享到

.net core 1.1下的EntityFramework Code First

2024-04-02 19:04:59 332人浏览 薄情痞子
摘要

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

新建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
{
    /// <summary>
    /// 数据库对象
    /// </summary>
    public class PermissionContext : DbContext
    {
        public PermissionContext(DbContextOptions<PermissionContext> opt) : base(opt)
        {
        }
        protected override void OnModelCreating(ModelBuilder modelBuilder)
        {
            //确定UserRole表中的两个字段是联合主键
            modelBuilder.Entity<UserRole>()
                .HasKey(u=>new { u.UserID,u.RoleID});
        }
        public DbSet<User> Users
        { get; set; }
        public DbSet<Role> Roles
        { get; set; }
 
        public DbSet<UserRole> UserRoles
        { get; set; }
    }
    /// <summary>
    /// 用户表
    /// </summary>
    public class User
    {
        [Key]
        public int ID
        { get; set; }
        public string UserName
        { get; set; }
 
        public string PassWord
        { get; set; }
 
        public List<UserRole> UserRoles { get; set; }
    }
    /// <summary>
    /// 角色表
    /// </summary>
    public class Role
    {
        [Key]
        public int ID
        { get; set; }
        public string RoleName
        {
            get;set;
        }
        public List<UserRole> UserRoles { get; set; }
    }
    /// <summary>
    /// 用户角色关系
    /// </summary>
    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<PermissionContext>(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


您可能感兴趣的文档:

--结束END--

本文标题: .net core 1.1下的EntityFramework Code First

本文链接: https://www.lsjlt.com/news/50575.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • .net core 1.1下的EntityFramework Code First
    新建asp.net core项目,然后把.net core引用的类库升级到1.1,这时,需要手动在project.json下添加一个runtimes节点,如下:"runtimes": { ...
    99+
    2024-04-02
  • .Net Core下使用Dapper的方法
    目录一、前言二、Dapper环境搭建三、Dapper封装定义DapperDBContext类异步分页构建(PageAsync)定义工作单元与事务定义数据仓储数据库连接四、Dapper...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作