You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

53 lines
1.6 KiB
C#

2 years ago
using EFCore7Study.DataService.Models;
using Microsoft.EntityFrameworkCore;
2 years ago
using Microsoft.Extensions.DependencyInjection;
2 years ago
namespace EFCore7Study.DataService
{
2 years ago
/// <summary>
/// 多构造函数
/// 为使用工厂方式注册,加 ActivatorUtilitiesConstructor 特性
/// </summary>
2 years ago
public class AppDbContext : DbContext
{
2 years ago
/// <summary>
/// 连接字符串可实现属性设置避免多构造函数在Factory时IoC异常
/// </summary>
public string? ConnectString = @"Server=127.0.0.1\SQL2019;Database=EFCore7Study;User Id=sa;Password=gly-bicijinlian;Encrypt=True;TrustServerCertificate=True;";
2 years ago
public AppDbContext()
{
}
2 years ago
public AppDbContext(DbContextOptions<AppDbContext> options) : base(options)
2 years ago
{
}
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
if (!optionsBuilder.IsConfigured)
{
2 years ago
if (string.IsNullOrWhiteSpace(ConnectString))
2 years ago
{
2 years ago
ConnectString = @"Server=127.0.0.1\SQL2019;Database=EFCore7Study;User Id=sa;Password=gly-bicijinlian;Encrypt=True;TrustServerCertificate=True;";
2 years ago
}
optionsBuilder
2 years ago
.UseSqlServer(ConnectString)
2 years ago
.EnableSensitiveDataLogging();
}
}
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.Entity<Account>().ToTable("Account");
base.OnModelCreating(modelBuilder);
}
public DbSet<Account> Accounts { get; set; }
}
}