第一章 EF Core CodeFirst 环境搭建
文章目录系列文章目录前言一、EF Core CodeFirst?二、使用步骤
1.创建项目2.创建实体3.创建EF Core DbContext4.创建Controller 测试查询数据 总结
前言随时微服务和DDD越来越流行,自己也想尝试着搭建一个完整的后端框架,有些人可能会说重复造轮子,其实我最开始也是这样考虑直接用ABP vnext不是很好吗? 但是从我用ABP之后的感受是,ABP还是对我这种水平比较普通的程序员来讲过框架过于重了,从现在开始我可能会从我的理解一步一步搭建DDD的服务框架。
一、EF Core CodeFirst?EF Core 是一个 O/RM(Object Relational Mapping)对象关系映射框架。这也是要实现DDD领域驱动的基础设施。
二、使用步骤 1.创建项目1.1 新建类库-领域层,名称可自定义如xxx.xxx.Domain
1.2 新建类库-领域层共通,名称可自定义如xxx.xxx.Domain.Shared
代码如下(示例):" />
1.3 新建Asp.Net core Web API,名称可自定义如 xxx.xxx.EntityframeworkCore
在EntityframeworkCore项目中 NuGet添加如下
2.1 在Domain项目中创建实体Entity
////// 基础字典 /// public class BasicDictionary { [Key] public Guid ID { get; set; } ////// 字典代码 /// [MaxLength(40),Required] public string Code { get; set; } ////// 字典名称 /// [MaxLength(80), Required] public string Name { get; set; } ////// 拼音码 /// [MaxLength(40), Required] public string PinYinCode { get; set; } ////// 字典类型 /// [Required] public BasicDictionaryType Type { get; set; } ////// 字典状态 /// [Required] public BasicDictionaryStatus Status { get; set; } ////// 排序 /// [Required] public int Sort { get; set; } }
2.2 在Domain.Shared 项目中创建枚举类
///3.创建EF Core DbContext/// 基础字典状态 /// public enum BasicDictionaryStatus { Invalid = 0, Valid = 1 } ////// 基础字典类别 /// public enum BasicDictionaryType { WarehouseType = 0, }
3.1 在EntityframeworkCore 项目中创建DbContext
public class PSIDbContext : DbContext
{
public DbSet BasicDictionaries { get; set; }
///
///
///
///
public PSIDbContext(DbContextOptions options)
: base(options)
{
}
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
base.OnConfiguring(optionsBuilder);
}
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
base.OnModelCreating(modelBuilder);
}
}
在appsettings.json中添加数据库连接字符串
"connectionStrings": {
"default": "Data Source=xxx;Initial Catalog=temp;User Id =xxx;Password=xxx"
},
在Program中添加EF配置
#region ef
var configurationBuilder = new ConfigurationBuilder()
.SetbasePath(Directory.GetCurrentDirectory())
.AddJsonFile("appsettings.json");
var config = configurationBuilder.Build();
builder.Services.AddDbContext(options => options.UseSqlServer(config["connectionStrings:default"]));
#endregion
3.2 在程序包管理控制台执行命令进行迁移及更新。
打开VS 工具→NuGet包管理器→程序包管理控制台。
首先输入Add-Migration innit执行,接着输入Update-Database执行。
4.1 创建controller
[ApiController]
[Route("[controller]")]
public class BasicDictionaryController : Controllerbase
{
private PSIDbContext _context;
public BasicDictionaryController(PSIDbContext context)
{
_context = context;
}
[HttpGet]
public IEnumerable Get()
{
using (_context)
{
//使用ef添加一条数据
BasicDictionary basicDictionary = new BasicDictionary();
basicDictionary.ID = Guid.NewGuid();
basicDictionary.Code = "1";
basicDictionary.Name = "2";
basicDictionary.Sort = 0;
basicDictionary.Type = Domain.Shared.BasicDictionaryType.WarehouseType;
basicDictionary.PinYinCode = "*";
basicDictionary.Status = Domain.Shared.BasicDictionaryStatus.Valid;
_context.BasicDictionaries.Add(basicDictionary);
_context.SaveChanges();
var items = _context.BasicDictionaries.Where(b => true).ToList();
return items;
}
}
}
在浏览器输入地址 http://localhost:xxx/BasicDictionary 测试即可。
总结最终项目目录结构如下
以上就是今天要讲的内容,本文仅仅简单介绍了EF core code first的搭建,随着章节的深入会不断完善各个部分功能,谢谢大家。



