EF Core 实战教程(七)通过读取appsetting.json数据库链接字符串链接数据库
《EF Core 实战教程(一)配置环境及使用code first 创建数据库》文章介绍了EF Core如何链接数据库,当时把数据库链接字符串写到代码里面了,实际开发中数据库链接字符串一般写到配置文件中,本文主要讲解如果读取配置文件中的链接字符串连接数据库,首先在项目中的appsetting.json文件中增加数据库链接字符串。
appsetting.json配置文件代码如下:
{ "Logging": { "LogLevel": { "Default": "Information", "Microsoft.AspNetCore": "Warning" } }, "ConnectionStrings": { "ConnectionString": "Data Source=.;Initial Catalog=EFCoreTest;Persist Security Info=True;User ID=sa;Password=*******" }, "AllowedHosts": "*" }
然后需要修改DbContext实现类中的的代码:
修改之前:
public class TestDbContext:DbContext { //映射到数据库表名 public DbSet<Book> Books { get; set; } public DbSet<Person> Persons { get; set; } public DbSet<Dog> Dogs { get; set; } /// <summary> /// 重写OnConfiguring实现数据库连接 /// </summary> /// <param name="optionsBuilder"></param> protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder) { base.OnConfiguring(optionsBuilder); optionsBuilder.UseSqlServer("Data Source=.;Initial Catalog=Advanced11;Persist Security Info=True;User ID=sa;Password=*******"); } /// <summary> /// 加载第二步的Fluent Api实体配置 /// </summary> /// <param name="modelBuilder"></param> protected override void OnModelCreating(ModelBuilder modelBuilder) { base.OnModelCreating(modelBuilder); //从指定程序集里面添加实体配置类 modelBuilder.ApplyConfigurationsFromAssembly(this.GetType().Assembly); } }
修改之后的代码如下:
public class MyDbContext:DbContext { public DbSet<Person> Persons { get; set; } public DbSet<Education> Educations { get; set; } public DbSet<User> Users { get; set; } public DbSet<Leave> Leaves { get; set; } public DbSet<OrgUnit> OrgUnits { get; set; } //通过json 读取数据库连接字符串 //依赖于 Microsoft.Extensions.Configuration; Microsoft.Extensions.Configuration.Json private ConfigurationBuilder cfgBuilder = new ConfigurationBuilder(); protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder) { base.OnConfiguring(optionsBuilder); cfgBuilder.AddJsonFile("appsettings.json",optional:true,reloadOnChange:true); IConfigurationRoot configRoot = cfgBuilder.Build(); string connStr = configRoot.GetSection("ConnectionStrings:ConnectionString").Value; optionsBuilder.UseSqlServer(connStr); //输出日志到控制台-方式1 optionsBuilder.LogTo(msg => { if (!msg.Contains("CommandExecuting")) return; Console.WriteLine(msg); }); } protected override void OnModelCreating(ModelBuilder modelBuilder) { base.OnModelCreating(modelBuilder); //从指定程序集里面添加实体配置类 modelBuilder.ApplyConfigurationsFromAssembly(this.GetType().Assembly); } }
猜您可能还喜欢
- EF Core 实战教程(八)一对多关系配置(1125)
- EF Core 实战教程(四)EF Core如何设置主键(909)
- EF Core 实战教程(六)如何查看EF Core生成的Sql语句(893)
- EF Core 实战教程(七)通过读取appsetting.json数据库链接字符串链接数据库(821)
- EF Core 实战教程(三)Fluent Api配置详解(595)
- EF Core 实战教程(一)配置环境及使用code first 创建数据库(587)
- EF Core 实战教程(五)Migrations深入研究及使用详解(525)
- EF Core 实战教程(二)实现基本的查询、增加、修改、删除功能(514)
- 解决Asp.net Core Razor页面调试时无法实时更新(502)
- EF Core实现充血模型(478)
评论列表
发表评论
文章分类
文章归档
- 2025年3月 (1)
- 2024年6月 (2)
- 2024年5月 (2)
- 2024年4月 (4)
- 2024年3月 (30)
- 2024年1月 (4)
- 2023年12月 (2)
- 2023年11月 (4)
- 2023年10月 (4)
- 2023年9月 (6)
- 2023年3月 (2)
- 2023年2月 (1)
- 2023年1月 (1)
- 2022年12月 (1)
- 2022年9月 (21)
- 2022年8月 (10)
- 2022年7月 (3)
- 2022年4月 (1)
- 2022年3月 (13)
- 2021年8月 (1)
- 2021年3月 (1)
- 2020年12月 (42)
- 2020年11月 (7)
- 2020年10月 (5)
- 2020年8月 (1)
- 2020年6月 (1)
- 2020年3月 (2)
- 2019年12月 (8)
- 2019年11月 (3)
- 2019年9月 (1)
- 2019年4月 (1)
- 2019年3月 (6)
- 2019年2月 (1)
- 2018年7月 (7)
阅读排行
- 1.asp.net mvc内微信pc端、H5、JsApi支付方式总结(5702)
- 2.各大搜索网站网站收录提交入口地址(3201)
- 3.Windows 10休眠文件更改存储位置(3164)
- 4.ECharts仪表盘实例及参数使用详解(3095)
- 5.windows 10安装myeclipse 10破解补丁cracker.jar、run.bat闪退解决办法(2992)
- 6.HTML5 WebSocket与C#建立Socket连接实现代码(2866)
- 7.华为鸿蒙系统清除微信浏览器缓存方法(2784)
- 8.CERT_HAS_EXPIRED错误如何解决(2249)
- 9.Js异步async、await关键字详细介绍(lambda表达式中使用async和await关键字)(2189)
- 10.HBuilder编辑器格式化代码(2118)