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 实战教程(八)一对多关系配置(1268)
- EF Core 实战教程(四)EF Core如何设置主键(1209)
- EF Core 实战教程(六)如何查看EF Core生成的Sql语句(1159)
- EF Core 实战教程(七)通过读取appsetting.json数据库链接字符串链接数据库(1066)
- EF Core 实战教程(三)Fluent Api配置详解(728)
- EF Core 实战教程(一)配置环境及使用code first 创建数据库(696)
- 解决Asp.net Core Razor页面调试时无法实时更新(693)
- EF Core 实战教程(五)Migrations深入研究及使用详解(619)
- EF Core 实战教程(二)实现基本的查询、增加、修改、删除功能(601)
- EF Core实现充血模型(600)
评论列表
发表评论
文章分类
文章归档
- 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支付方式总结(5920)
- 2.Windows 10休眠文件更改存储位置(4013)
- 3.各大搜索网站网站收录提交入口地址(3506)
- 4.windows 10安装myeclipse 10破解补丁cracker.jar、run.bat闪退解决办法(3482)
- 5.ECharts仪表盘实例及参数使用详解(3465)
- 6.华为鸿蒙系统清除微信浏览器缓存方法(3258)
- 7.HTML5 WebSocket与C#建立Socket连接实现代码(3222)
- 8.CERT_HAS_EXPIRED错误如何解决(3022)
- 9.Js异步async、await关键字详细介绍(lambda表达式中使用async和await关键字)(2667)
- 10.HBuilder编辑器格式化代码(2430)
