zoukankan      html  css  js  c++  java
  • asp.net EFcore配置链接sqlserver

    1. 首先我们先用vs2017 创建一个空的 asp.net core api 项目

    2.  在生成的解决方案下在建立一个访问数据库使用的类库CoreApi.Model,注意要选择.netcore下的类库,如图所示

    二 添加相关引用

    1. 打开nuget包的程序管理命令控制台,执行添加引用命令 ,注意执行时控制台的默认项目要定位为 CoreApi.Model

         

    引用 EntityFrameworkCore

    Install-Package Microsoft.EntityFrameworkCore

    引用 EntityFrameworkCore.SqlServer

    Install-Package Microsoft.EntityFrameworkCore.SqlServer

    引用 EntityFrameworkCore.SqlServer.Tools

    Install-Package Microsoft.EntityFrameworkCore.Tools

    三 相关配置

    1. 在appsettings.json 文件中添加sqlserver的数据库链接配置,配置如下

    复制代码
    {
      "ConnectionStrings": {
        "SqlServerConnection": "Server=.;Database=dbCore;User ID=sa;Password=abc123456;"
      },
      "Logging": {
        "IncludeScopes": false,
        "LogLevel": {
          "Default": "Warning"
        }
      }
    }
    复制代码

    2.修改项目Startup.cs 文件 的ConfigureServices 方法,注意此处必须引用 using Microsoft.EntityFrameworkCore

    以及using CoreApi.Model; 

    复制代码
     public void ConfigureServices(IServiceCollection services)
            {
                var sqlConnection = Configuration.GetConnectionString("SqlServerConnection");
                services.AddDbContext<ApiDBContent>(option => option.UseSqlServer(sqlConnection));
                services.AddMvc();
            }
    复制代码

    四 生成数据库

    1. 首先在CoreApi.Model下建立在UserInfo 用户模型  

    2. 复制代码
      public  class UserInfo
          { 
                  public int Id { get; set; }
                  public string UserName { get; set; }
                  public string Password { get; set; }
          }
      复制代码

       配置数据上下文

    3. 复制代码
      public class ApiDBContent : DbContext
              {
                  public ApiDBContent(DbContextOptions<ApiDBContent> options)
                      : base(options)
                  {
                  }
                  public DbSet<UserInfo> Users { get; set; }
              }
      复制代码

      打开程序包管理控制台,执行 Add-Migration Migrations 命令,注意此时默认项目也必须定位CoreApi.Model,

            

    如果顺利的话项目下应该会生成一个Migrations的文件夹并包含一些初始化生成数据库需要用的文件

    4.执行 update-database 命令生成数据库,

    五 简单的数据库迁移

    1.  我们新增一个Articles 模型  在userinfo中增加两个字段,使用命令将其更新至数据库,还是需要注意默认项目也必须定位CoreApi.Model,因为我们所有的数据库操作都是针对model层的      

    复制代码
     public  class UserInfo
        { 
                public int Id { get; set; }
                public string UserName { get; set; }
                public string Password { get; set; }
                public string Phone { get; set; }
                public virtual List<Articles> Articles { get; set; }
        }
    
        public class Articles
        {
            public int Id { get; set; }
            public string Title { get; set; }
            public string summary { get; set; }
            public virtual UserInfo  User{get;set;}
    
        }
    复制代码
    1. 我们执行 命令 Add-Migration migrationName 和 update-datebase   成功后刷新数据库可以看到表和字段都相应的加上了 ,当然还有外键

    六 最后我们在数据库中初始化一些数据 然后使用efcore 请求数据

    1. 在数据库初始用户数据

    2.  构造函数方式初始化数据上下文, 简单修改ValuesController 下的 Get 方法

    复制代码
    private readonly ApiDBContent _dbContext;
     
            public ValuesController(ApiDBContent dbContext)
            {
                _dbContext = dbContext;
            }
            // GET api/values
            [HttpGet]
            public JsonResult Get()
            {
                return Json(_dbContext.Users.Take(2).ToList()) ;
                //return new string[] { "value1", "value2" };
            }
    复制代码

    3.  启动项目 请求get api  

  • 相关阅读:
    [置顶] Spring的自动装配
    BZOJ2831(小强的金字塔系列问题--区域整点数求法)
    国际跆拳道联盟
    Linux如何查找某个时间点后生成的空文件
    ORACLE中关于外键缺少索引的探讨和总结
    ORA-12514, TNS:listener does not currently know of service requested in connect descriptor案例2
    SQL Server 2005 sp_send_dbmail出现Internal error at FormatRowset (Reason: Not enough storage is available to complete this operation)
    SQL Server数据库邮件发送异常案例
    MySQL二进制日志总结
    OSWatcher使用过程中小问题解决方法
  • 原文地址:https://www.cnblogs.com/zxtceq/p/13718909.html
Copyright © 2011-2022 走看看