PetaPoco在ASP.NET Core 2.2中使用注入方式访问数据库

Posted mzy-google

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了PetaPoco在ASP.NET Core 2.2中使用注入方式访问数据库相关的知识,希望对你有一定的参考价值。

.Net Core中一个特别重要的特性就是依赖注入功能,那么我们在使用PetaPoco的时候是否也可以使用依赖注入特性呢?

回答当然是可以的啦。使用方法(两种注入方式)如下

services.AddScoped<IDatabase>(
    x =>
       {
           var connectionStrnig = Configuration["ConnectionStrings:mysql:MvcMySQL"];
           var configuration = DatabaseConfiguration.Build().UsingConnectionString(connectionStrnig)
                            .UsingProvider<MariaDbDatabaseProvider>();
           return new PetaPocoMvcDBContext(configuration);
       });
 
services.AddScoped<IDatabase, PetaPocoMvcDBContext>(
    (x) =>
         {
             var connectionStrnig = Configuration["ConnectionStrings:MySQL:MvcMySQL"];
             var configuration = DatabaseConfiguration.Build().UsingConnectionString(connectionStrnig)
                            .UsingProvider<MariaDbDatabaseProvider>();
             return new PetaPocoMvcDBContext(configuration);
         });

定义的PetaPocoMvcDBContext类:

namespace PetaPocoEfCoreMvc.DBContext
{
    using System.Data.Common;
 
    using PetaPoco;
    using PetaPoco.Core;
 
    public class PetaPocoMvcDBContext:Database
    {
        public PetaPocoMvcDBContext(DbConnection connection, IMapper defaultMapper = null)
            : base(connection, defaultMapper)
        {
        }
 
        public PetaPocoMvcDBContext(string connectionString, string providerName, IMapper defaultMapper = null)
            : base(connectionString, providerName, defaultMapper)
        {
        }
 
        public PetaPocoMvcDBContext(string connectionString, DbProviderFactory factory, IMapper defaultMapper = null)
            : base(connectionString, factory, defaultMapper)
        {
        }
 
        public PetaPocoMvcDBContext(string connectionString, IProvider provider, IMapper defaultMapper = null)
            : base(connectionString, provider, defaultMapper)
        {
        }
 
        public PetaPocoMvcDBContext(IDatabaseBuildConfiguration configuration)
            : base(configuration)
        {
        }
    }
}

appsetting.json中的数据库连接字符串:

"ConnectionStrings": {
    "MySQL": {
      "MvcMySQL": "server=127.0.0.1;port=3306;uid=root;pwd=123456;database=WireCloud;",
      "provider": "MySql.Data.MySqlClient"
    }
  }

添加UserService相关类:

namespace PetaPocoEfCoreMvc.Service
{
    using PetaPocoEfCoreMvc.Models;

    public interface IUserService
    {
        IEnumerable<User> GetAll();
    }
}


namespace PetaPocoEfCoreMvc.Service
{
    using PetaPoco;
    using PetaPocoEfCoreMvc.Models;

    public class UserService:IUserService
    {
        private readonly IDatabase _database;
      //构造函数注入
        public UserService(IDatabase database)
        {
            _database = database;
        }

        public IEnumerable<User> GetAll()
        {
            return _database.Fetch<User>();
        }
    }
}

 

以上是关于PetaPoco在ASP.NET Core 2.2中使用注入方式访问数据库的主要内容,如果未能解决你的问题,请参考以下文章

如何在 ASP.NET Core 2.2 中实现标识

总结:利用asp.net core日志进行生产环境下的错误排查(asp.net core version 2.2,用IIS做服务器)

如何在 ASP.NET Core 2.2 中使用 IValidateOptions 验证配置设置?

Asp .NET Core 2.2 Razor 页面布局和局部

ASP.NET Core 2.2 JWT 身份验证

Simple ASP.NET CORE 2.2 App +Vue JS