C#给SqlSugar封装一个单例类

.NET兼职社区

可以直接用,轻量方便,无需重复造轮子。 这里只对CRUD进行封装,我的应用比较简单。

csharp 复制代码
using SqlSugar;
using System.Collections.Generic;


namespace MusicApp.Assist
{
    internal class SqlSugarAssist
    {
        private static readonly object _lock = new object();
        private static SqlSugarAssist _instance;
        private readonly ISqlSugarClient _db;
        private SqlSugarAssist(string connectionString)
        {
            _db = new SqlSugarClient(new ConnectionConfig()
            {
                ConnectionString = connectionString,
                DbType = DbType.SqlServer, // 或其他数据库类型
                IsAutoCloseConnection = true
            });
        }

        ///单例实现
        public static SqlSugarAssist GetInstance(string connectionString) 
        {
            if (_instance == null) 
            {
                lock (_lock) {
                    if (_instance == null) 
                    {
                        _instance=new SqlSugarAssist(connectionString); 


                    }
                }
            }
            return _instance;
        }



        // 插入操作
        public int Insert<T>(T entity) where T : class,new()
        {
            return _db.Insertable(entity).ExecuteCommand();
        }

        // 删除操作
        public int Delete<T>(dynamic list) where T : class, new()
        {
            return _db.Deleteable<T>(list).ExecuteCommand();
        }

        // 更新操作
        public int Update<T>(T entity) where T : class, new()
        {
            return _db.Updateable(entity).ExecuteCommand();
        }

        // 查询操作
        public List<T> Select<T>()
        {
            return _db.Queryable<T>().ToList();
        }

    }
}
相关推荐
兑生几秒前
【灵神题单·贪心】3745. 三元素表达式的最大值 | 排序贪心 | Java
java·开发语言
polaris06306 分钟前
Windows操作系统部署Tomcat详细讲解
java·windows·tomcat
sqyno1sky8 分钟前
C++中的契约编程
开发语言·c++·算法
卓怡学长21 分钟前
m280本科生导师指导平台
java·数据库·spring·tomcat·maven·intellij-idea
python猿22 分钟前
打卡Python王者归来--第30天
开发语言·python
qq_3349031523 分钟前
嵌入式C++驱动开发
开发语言·c++·算法
阿贵---34 分钟前
C++代码规范化工具
开发语言·c++·算法
暮冬-  Gentle°42 分钟前
自定义内存检测工具
开发语言·c++·算法
一直都在57242 分钟前
Java死锁
java·开发语言
娇娇yyyyyy1 小时前
QT编程(15): Qt 按键事件和定时器事件
开发语言·qt