zoukankan      html  css  js  c++  java
  • Asp.net Core 3.1 引用ORM工具包 yrjw.ORM.Chimp(EF + dapper + Autofac)使用教程

    yrjw.ORM.Chimp

    介绍

    It is not the encapsulation of ORM,a based on EF + dapper + Autofac, is repository and unitofwork

    安装教程

    1. 程序包管理器控制台,使用 NuGet命令安装。 PM> Install-Package yrjw.ORM.Chimp

    2. 或者直接在项目文件.csproj中引入包

    使用说明

    1. 创建实体对象,继承IEntity
        /// <summary>
        /// 学生信息表
        /// </summary>
        [Table("StudentInfo")]
        public class StudentInfo: IEntity
        {
            [Key]
            public virtual int Id { get; set; }
            /// <summary>
            /// 学生姓名
            /// </summary>
            [Required]
            [Column(TypeName = "varchar(50)")]
            public string Name { get; set; }
            /// <summary>
            /// 性别
            /// </summary>
            public int Sex { get; set; }
            /// <summary>
            /// 民族
            /// </summary>
            public int NationId { get; set; }
            /// <summary>
            /// 电话
            /// </summary>
            public string Phone { get; set; }
        }
    1. 创建上下文,继承BaseDbContext,使用base.OnModelCreating(),无需添加DbSet
        public class myDbContext: BaseDbContext
        {
            public myDbContext()
            {
            }
    
            public myDbContext(DbContextOptions options) : base(options)
            {
            }
    
            protected override void OnModelCreating(ModelBuilder modelBuilder)
            {
                base.OnModelCreating(modelBuilder);
                modelBuilder.Seed(); //种子数据
            }
        }
    1. 添加扩展方法,初始化种子数据。
        public static class ModelBuilderExtensions
        {
            /// <summary>
            /// 种子数据
            /// </summary>
            /// <param name="modelBuilder"></param>
            public static void Seed(this ModelBuilder modelBuilder)
            {
                modelBuilder.Entity<StudentInfo>().HasData(
                    new StudentInfo { Id = 1, Name = "张三", Sex = 1, NationId = 1, Phone="13902451189"}
                    );
            }
        }
    1. 创建仓储接口和实现类,service继承IDependency接口,可支持通过属性依赖注入方式(使用Autofac依赖注入)。
        public interface IStudentInfoService
        {
            IUnitOfWork UnitOfWork { get; }
    
            Task<IResultModel> QueryList();
        }
        public class StudentInfoService: IStudentInfoService, IDependency
        {
            private readonly Lazy<IMapper> _mapper;
            private readonly Lazy<IRepository<StudentInfo>> repStudentInfo;
    
            public IUnitOfWork UnitOfWork { get; }
    
            public StudentInfoService(Lazy<IMapper> mapper, IUnitOfWork unitOfWork, Lazy<IRepository<StudentInfo>> repStudentInfo)
            {
                this._mapper = mapper;
                this.UnitOfWork = unitOfWork;
                this.repStudentInfo = repStudentInfo;
            }
    
            public async Task<IResultModel> QueryList()
            {
                var list = await repStudentInfo.Value.TableNoTracking.ProjectTo<StudentInfoDTO>(_mapper.Value.ConfigurationProvider).ToListAsync();
                return ResultModel.Success<IList<StudentInfoDTO>>(list);
            }
        }
    1. 添加控制器Controller
        [Description("学生信息")]
        [Route("api/[controller]/[action]")]
        public class StudentInfoController : ControllerBase
        {
            private readonly ILogger<StudentInfoController> _logger;
    
            public Lazy<IStudentInfoService> StudentInfoService { get; set; }
    
            public StudentInfoController(ILogger<StudentInfoController> logger)
            {
                _logger = logger;
            }
    
            [Description("获取学生列表")]
            [ResponseCache(Duration = 0)]
            [HttpGet]
            public Task<IResultModel> QueryList()
            {
                return StudentInfoService.Value.QueryList();
            }
        }
    1. 最关键一步,Startup.cs中注入服务,setting.AssemblyName为当前运行的api程序集命名空间。
        public virtual void ConfigureServices(IServiceCollection services)
        {
            if (setting.DbType == yrjw.ORM.Chimp.DbType.MYSQL)
            {
                services.AddChimp<myDbContext>(opt => opt.UseMySql(setting.ConnectionString,
                    b => b.MigrationsAssembly(setting.AssemblyName)));
            }
            else
            {
                services.AddChimp<myDbContext>(opt => opt.UseSqlServer(setting.ConnectionString,
                    b => b.MigrationsAssembly(setting.AssemblyName)));
            }
        }

    详细使用说明

    使用说明

    关于Chimp

    在Leo.Chimp包基础上添加了Autofac依赖注入,封装返回接口模型IResultModel,支持.net core 3.1版本上使用。

  • 相关阅读:
    plsql查询中文乱码
    ORA-12514: TNS:listener does not currently know of service requested in connect
    linux 手动配置ip地址方法
    开机自起tomcat
    (静默安装)Cent OS 6_5(x86_64)下安装Oracle 11g
    Linux下启动Oracle服务和监听程序
    linux下强制安装rpm包
    谷歌浏览器如何将整个网页保存为图片
    C语言移位和位运算
    MySQL连接的使用
  • 原文地址:https://www.cnblogs.com/han1982/p/12736150.html
Copyright © 2011-2022 走看看