首页 > 数据库 >sqlsugar 单例模式 封装

sqlsugar 单例模式 封装

时间:2024-08-29 19:26:21浏览次数:14  
标签:DbInfo 封装 string connectStr dbInfo 单例 new public sqlsugar

using System.Linq.Expressions;
using Microsoft.Extensions.Configuration;
using SqlSugar;

namespace SqlSugarFrameworkCore;

public class DbSettings
{
public const string AppOne = "AppOne";
public const string AppDevOne = "AppDevOne";
public const string AppThreeOne = "AppThreeOne";
public const string Oracle = "Oracle";
}

public enum DbInfo
{
MesOne = 1,
MesDevOne = 2,
MesThree = 3,
Oracle = 4,
}

public class LongSugarClient
{
public static LongSugarClient sugarInstance;
public static DbInfo curDbInfo;
public static Dictionary<DbInfo, LongSugarClient> sugarInstances = new Dictionary<DbInfo, LongSugarClient>();

public static readonly object sugarInstanceLock = new object();
public SqlSugarClient _db;

private LongSugarClient(SqlSugarClient sqlSugarClient)
{
    _db = sqlSugarClient;
}

public static LongSugarClient GetInstance(DbInfo dbInfo, IConfigurationSection dbConfigurationSection)
{
    if (sugarInstances.ContainsKey(dbInfo))
    {
        sugarInstances.TryGetValue(dbInfo, out LongSugarClient sugarInstance);
        return sugarInstance;
    }

    lock (sugarInstanceLock)
    {
        if (sugarInstances.ContainsKey(dbInfo))
        {
            sugarInstances.TryGetValue(dbInfo, out LongSugarClient sugarInstance);
            return sugarInstance;
        }
        GetSugarClient(dbInfo, dbConfigurationSection);
    }
    return sugarInstance;
}

private static void GetSugarClient(DbInfo dbInfo, IConfigurationSection dbConfigurationSection)
{
    if (dbInfo == DbInfo.MesOne)
    {
        string connectStr = dbConfigurationSection.GetSection(DbSettings.AppOne).Value ?? throw new ArgumentNullException($"{DbSettings.AppOne} is misstion");
        CreateSugarClient(dbInfo, connectStr);
    }
    else if (dbInfo == DbInfo.MesDevOne)
    {
        string connectStr = dbConfigurationSection.GetSection(DbSettings.AppDevOne).Value ?? throw new ArgumentNullException($"{DbSettings.AppDevOne} is misstion");
        CreateSugarClient(dbInfo, connectStr);
    }
    else if (dbInfo == DbInfo.MesThree)
    {
        string connectStr = dbConfigurationSection.GetSection(DbSettings.AppThreeOne).Value ?? throw new ArgumentNullException($"{DbSettings.AppThreeOne} is misstion");
        CreateSugarClient(dbInfo, connectStr);
    }
    else if (dbInfo == DbInfo.Oracle)
    {
        string connectStr = dbConfigurationSection.GetSection(DbSettings.Oracle).Value ?? throw new ArgumentNullException($"{DbSettings.Oracle} is misstion");
        CreateSugarClient(dbInfo, connectStr);
    }
}

private static void CreateSugarClient(DbInfo dbInfo, string connectStr)
{
    SqlSugarClient sqlSugar = new SqlSugarClient(
        new ConnectionConfig()
        {
            DbType = SqlSugar.DbType.SqlServer,
            ConnectionString = connectStr,
            IsAutoCloseConnection = true,
        },
        db =>
        {
            //单例参数配置,所有上下文生效
            db.Aop.OnLogExecuting = (sql, pars) =>
            {
                //打印日志
                Console.WriteLine(sql + "\r\n" + db.Utilities.SerializeObject(pars.ToDictionary(it => it.ParameterName, it => it.Value)));
            };
        }
    );
    sugarInstance = new LongSugarClient(sqlSugar);
    sugarInstances.Add(dbInfo, sugarInstance);
}

private DbInfo? GetCurrentDbInfo()
{
    foreach (KeyValuePair<DbInfo, LongSugarClient> pair in sugarInstances)
    {
        if (pair.Value == this)
        {
            return pair.Key;
        }
    }
    return null;
}


public void Excute()
{
    dynamic dynamic = this._db.SqlQueryable<dynamic>("select count(*) as count FROM [dbo].[MBO_EqInfo]").First();
    System.Console.WriteLine(dynamic.ToSqlValue);
}

}

标签:DbInfo,封装,string,connectStr,dbInfo,单例,new,public,sqlsugar
From: https://www.cnblogs.com/zhuoss/p/18387216

相关文章

  • SpringBoot把本地的对象封装成为Nacos的配置对象
    你需要有个NacosNacos建立你的配置文件--建议yml文件编写你的yml配置platform:transaction:properties:notifyHost:"http://10.130.1.18:${server.port.cztech-service-gateway}"smsTemplate:"TEM_0029"#订单默认过期时间--分钟defau......
  • python读取配置文件&&简单封装 公共配置文件 config
    之前有做过把爬虫数据写到数据库中的练习,这次想把数据库信息抽离到一个ini配置文件中,这样做的好处在于可以在配置文件中添加多个数据库,方便切换(另外配置文件也可以添加诸如邮箱、url等信息)1.configparser模块python使用自带的configparser模块用来读取配置文件,配置文......
  • pygame封装常用控件,第二日,有滑块的文本显示域
    #coding=utf-8importos,sys,re,timeimportpygameimportrandomfromwin32apiimportGetSystemMetricsfromtkinterimportmessageboxpygame.init()pygame.display.set_caption("我的控件")percent=0.6screen_width=GetSystemMetrics(0)screen_heig......
  • 《C++中的友元:打破封装的神秘力量》
    在C++的编程世界里,友元函数和友元类就像是一把特殊的钥匙,可以打开封装的大门,让特定的函数或类能够访问其他类的私有成员。这一特性在某些情况下具有重要的作用,让我们一起来深入探讨C++中的友元函数和友元类有什么作用。一、热点关注:友元为何引发热议?在面向对象编程中,封......
  • 【设计模式】单例模式(线程安全)
     ......
  • 在做结果集封装时,若结果集表头与成员变量名不一致该如何解决?
    目录1.通过别名映射为一致:as子句2.使用resultMap3.在配置文件中开启适配规则在Score实体类中,我们定义了studentId、courseId、score、status,而在数据库中,我们设置如下:1.通过别名映射为一致:as子句在持久层接口中,我们定义了select1()方法,返回类型为List<Score>。由于......
  • 单例模式 lock 多线程 双重检查锁定机制
    单例模式单例模式publicclassSingleton{//定义一个静态变量来保存类的实例privatestaticSingletonuniqueInstance;//定义一个标识确保线程同步privatestaticreadonlyobjectlocker=newobject();//定义私有构造函数,使外界不能创建该类......
  • JS单例模式; super return 改变this
    简单的单例首先js中的函数是一种特殊的对象,这使得他可以存储属性functionaaa(params){}//undefinedaaa.lalala=123//123js中的类是通过原型链继承的,因此类就是函数的集合体,可以通过babel编译看看。因此可以写出简单的单例模式classSingleton{constructor(da......