栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

(1)从零开始搭建基于DDD的.net core6.0后端服务

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

(1)从零开始搭建基于DDD的.net core6.0后端服务

系列文章目录

第一章 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.创建实体

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 项目中创建枚举类

/// 
    /// 基础字典状态
    /// 
    public enum BasicDictionaryStatus
    {
        Invalid = 0,
        Valid = 1
    }

 /// 
    /// 基础字典类别
    /// 
    public enum BasicDictionaryType
    {
        WarehouseType = 0,
    }
3.创建EF Core DbContext

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.创建Controller 测试查询数据

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的搭建,随着章节的深入会不断完善各个部分功能,谢谢大家。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/782699.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号