zoukankan      html  css  js  c++  java
  • Dapper 简单封装

    using System;
    using System.Collections.Generic;
    using System.Text;
    using Dapper;
    using System.Data;
    using System.Data.SqlClient;
    using System.Linq;
    using System.Linq.Expressions;
    using common.core.config;
    using Npoi.Core.SS.Formula.Functions;
    
    namespace common.core.sqlserver
    {
        public class BaseService<TService, TEntity> where TService : BaseService<TService, TEntity>, new()
        {
            /// <summary>
            /// 默认实例
            /// </summary>
            /// <returns>服务实例</returns>
            public static TService Instance() => new TService();
     
            /// <summary>
            /// 插入多个
            /// </summary>
            /// <param name="listModel"></param>
            public virtual int InsertMany(List<TEntity> listModel)
            {
                if (listModel == null || listModel.Count <= 0)
                {
                    throw new Exception("插入数据不可为空");
                }
                TEntity model = listModel.FirstOrDefault();
                var ps = model.GetType().GetProperties();
                List<string> @colms = new List<string>();
                List<string> @params = new List<string>();
    
                foreach (var p in ps)
                {
                    if (p.CustomAttributes.All(x => x.AttributeType != typeof(PrimaryKeyAttribute)) && p.CustomAttributes.All(x => x.AttributeType != typeof(DBIgnoreAttribute)))
                    {
                        @colms.Add(string.Format("[{0}]", p.Name));
                        @params.Add(string.Format("@{0}", p.Name));
                    }
                }
                var sql = string.Format("INSERT INTO [{0}] ({1}) VALUES({2})", typeof(TEntity).Name, string.Join(", ", @colms), string.Join(", ", @params));
                using (var _conn = new SqlConnection(CommonConfigUtil.GlobalConfigExtend.SqlServer.Url))
                {
                    IDbTransaction transaction = _conn.BeginTransaction();
                    return _conn.Execute(sql, listModel, transaction, null, null);
                }
    
            }
    
            /// <summary>
            /// 插入一个
            /// </summary>
            /// <param name="model"></param>
            public virtual int InsertOne(TEntity model)
            {
                if (model == null)
                {
                    throw new Exception("插入数据不可为空");
                }
                var ps = model.GetType().GetProperties();
                List<string> @colms = new List<string>();
                List<string> @params = new List<string>();
    
                foreach (var p in ps)
                {
                    if (p.CustomAttributes.All(x => x.AttributeType != typeof(PrimaryKeyAttribute)) && p.CustomAttributes.All(x => x.AttributeType != typeof(DBIgnoreAttribute)))
                    {
                        @colms.Add(string.Format("[{0}]", p.Name));
                        @params.Add(string.Format("@{0}", p.Name));
                    }
                }
                var sql = string.Format("INSERT INTO [{0}] ({1}) VALUES({2})", typeof(TEntity).Name, string.Join(", ", @colms), string.Join(", ", @params));
                using (var _conn = new SqlConnection(CommonConfigUtil.GlobalConfigExtend.SqlServer.Url))
                {
                    return _conn.Execute(sql, model, null, null, null);
                }
            }
    
            /// <summary>
            /// 查询一个
            /// </summary>
            /// <param name="whereProperties"></param>
            /// <returns></returns>
            public virtual TEntity GetOne(object whereProperties)
            {
                string where = "";
                var listPropert = whereProperties.GetType().GetProperties();
                if (listPropert.Length > 0)
                {
                    where += " where ";
                    listPropert.ToList().ForEach(e =>
                    {
                        where += $" {e.Name} = @{e.Name} and";
                    });
                }
                where = where.TrimEnd('d').TrimEnd('n').TrimEnd('a');
                //返回单条信息
                string query = $"SELECT * FROM { typeof(TEntity).Name}{where}";
                using (var _conn = new SqlConnection(CommonConfigUtil.GlobalConfigExtend.SqlServer.Url))
                {
                    return _conn.QuerySingleOrDefault<TEntity>(query, whereProperties);
                }
            }
    
            /// <summary>
            /// 查询一个
            /// </summary>
            /// <param name="where"></param>
            /// <returns></returns>
            public virtual TEntity GetOne(string where)
            {
                if (!string.IsNullOrEmpty(where))
                {
                    where = $" where 1=1 and {where}";
                }
                //返回单条信息
                string query = $"SELECT * FROM { typeof(TEntity).Name}  {where}";
                using (var _conn = new SqlConnection(CommonConfigUtil.GlobalConfigExtend.SqlServer.Url))
                {
                    return _conn.QuerySingleOrDefault<TEntity>(query);
                }
            }
    
            /// <summary>
            /// 查询多个
            /// </summary>
            /// <param name="whereProperties"></param>
            /// <returns></returns>
            public virtual List<TEntity> GetMany(object whereProperties)
            {
                string where = "";
                var listPropert = whereProperties.GetType().GetProperties();
                if (listPropert.Length > 0)
                {
                    where += " where ";
                    listPropert.ToList().ForEach(e =>
                    {
                        where += $" {e.Name} = @{e.Name} and";
                    });
                }
                where = where.TrimEnd('d').TrimEnd('n').TrimEnd('a');
                string query = $"SELECT * FROM { typeof(TEntity).Name}{where}";
                using (var _conn = new SqlConnection(CommonConfigUtil.GlobalConfigExtend.SqlServer.Url))
                {
                    return _conn.Query<TEntity>(query, whereProperties)?.ToList();
                }
            }
    
            /// <summary>
            /// 查询多个
            /// </summary>
            /// <param name="where"></param>
            /// <returns></returns>
            public virtual List<TEntity> GetMany(string where)
            {
                if (!string.IsNullOrEmpty(where))
                {
                    where = $" where 1=1 and {where}";
                }
                string query = $"SELECT * FROM { typeof(TEntity).Name}  {where}";
                using (var _conn = new SqlConnection(CommonConfigUtil.GlobalConfigExtend.SqlServer.Url))
                {
                    return _conn.Query<TEntity>(query)?.ToList();
                }
            }
    
            /// <summary>
            /// 是否存在
            /// </summary>
            /// <param name="whereProperties"></param>
            /// <returns></returns>
            public virtual bool Exists(object whereProperties)
            {
                return GetMany(whereProperties).Count > 0;
            }
    
            /// <summary>
            /// 是否存在
            /// </summary>
            /// <param name="where"></param>
            /// <returns></returns>
            public virtual bool Exists(string where)
            {
                return GetMany(where).Count > 0;
            }
    
            /// <summary>
            /// 删除
            /// </summary>
            /// <param name="entity"></param>
            /// <returns></returns>
            public virtual int DeleteById(TEntity entity)
            {
                if (entity == null)
                {
                    throw new Exception("删除内容不可为空");
                }
                string where = "";
                var listPropert = entity.GetType().GetProperties();
                if (listPropert.Length > 0)
                {
                    listPropert.ToList().ForEach(p =>
                    {
                        var primaryKey = p.CustomAttributes.FirstOrDefault(x => x.AttributeType == typeof(PrimaryKeyAttribute));
                        if (primaryKey != null)
                        {
                            where += $" {p.Name} = @{p.Name} and";
                        }
                    });
                }
    
                where = where.TrimEnd('d').TrimEnd('n').TrimEnd('a');
                if (string.IsNullOrEmpty(where))
                {
                    throw new Exception("未找到Id");
                }
                string query = $"DELETE FROM { typeof(TEntity).Name} where {where}";
                using (var _conn = new SqlConnection(CommonConfigUtil.GlobalConfigExtend.SqlServer.Url))
                {
                    return _conn.Execute(query, entity);
                }
            }
    
            /// <summary>
            /// 删除
            /// </summary>
            /// <param name="whereProperties"></param>
            /// <returns></returns>
            public virtual int Delete(object whereProperties)
            {
                string where = "";
                var listPropert = whereProperties.GetType().GetProperties();
                if (listPropert.Length > 0)
                {
                    listPropert.ToList().ForEach(e =>
                    {
                        where += $"{e.Name} = @{e.Name} and";
                    });
                }
                where = where.TrimEnd('d').TrimEnd('n').TrimEnd('a');
                if (string.IsNullOrEmpty(where))
                {
                    throw new Exception("条件不可为空");
                }
                string query = $"DELETE FROM { typeof(TEntity).Name} where {where}";
                using (var _conn = new SqlConnection(CommonConfigUtil.GlobalConfigExtend.SqlServer.Url))
                {
                    return _conn.Execute(query, whereProperties);
                }
            }
    
            /// <summary>
            /// 删除
            /// </summary>
            /// <param name="where"></param>
            /// <returns></returns>
            public virtual int Delete(string where)
            {
                if (string.IsNullOrEmpty(where))
                {
                    throw  new Exception("条件不可为空");
                }
                string query = $"DELETE FROM { typeof(TEntity).Name} where {where}";
                using (var _conn = new SqlConnection(CommonConfigUtil.GlobalConfigExtend.SqlServer.Url))
                {
                    return _conn.Execute(query);
                }
            }
    
            /// <summary>
            /// 根据Id更新
            /// </summary>
            /// <param name="entity"></param>
            /// <returns></returns>
            public virtual int UpdateById(TEntity entity)
            {
                if (entity == null)
                {
                    throw new Exception("更新内容不可为空");
                }
                string where = "";
                var listPropert = entity.GetType().GetProperties();
                if (listPropert.Length > 0)
                {
                    listPropert.ToList().ForEach(p =>
                    {
                        var primaryKey = p.CustomAttributes.FirstOrDefault(x => x.AttributeType == typeof(PrimaryKeyAttribute));
                        if (primaryKey!=null)
                        {
                            where += $" {p.Name} = @{p.Name} and";
                        }
                    });
                }
    
                where=where.TrimEnd('d').TrimEnd('n').TrimEnd('a');
                if (string.IsNullOrEmpty(where))
                {
                    throw new Exception("未找到Id");
                }
    
                string update = "";
                var listPropertUpdate = entity.GetType().GetProperties();
                if (listPropertUpdate.Length > 0)
                {
                    update += "";
                    listPropertUpdate.ToList().ForEach(e =>
                    {
                        if (e.CustomAttributes.All(x => x.AttributeType != typeof(PrimaryKeyAttribute)) && e.CustomAttributes.All(x => x.AttributeType != typeof(DBIgnoreAttribute)))
                        {
                            update += $"{e.Name} = @{e.Name} ,";
                        }
                    });
                }
                update = update.TrimEnd(',');
                if (string.IsNullOrEmpty(update))
                {
                    throw new Exception("无更新内容");
                }
                string query = $"update { typeof(TEntity).Name} set {update} where {where}";
                using (var _conn = new SqlConnection(CommonConfigUtil.GlobalConfigExtend.SqlServer.Url))
                {
                    return _conn.Execute(query, entity);
                }
    
            }
    
            /// <summary>
            /// 根据条件更新
            /// </summary>
            /// <param name="updateProperty"></param>
            /// <param name="where"></param>
            /// <returns></returns>
            public virtual int Update(object updateProperty, string where)
            {
                if (string.IsNullOrEmpty(where))
                {
                    throw new Exception("需输入条件");
                }
                string update = "";
                var listPropertUpdate = updateProperty.GetType().GetProperties();
                if (listPropertUpdate.Length > 0)
                {
                    update += "";
                    listPropertUpdate.ToList().ForEach(e =>
                    {
                        update += $"{e.Name} = @{e.Name} ,";
                    });
                }
                update = update.TrimEnd(',');
                if (string.IsNullOrEmpty(update))
                {
                    throw new Exception("无更新内容");
                }
                string query = $"update { typeof(TEntity).Name} set {update} where {where}";
                using (var _conn = new SqlConnection(CommonConfigUtil.GlobalConfigExtend.SqlServer.Url))
                {
                    return _conn.Execute(query, updateProperty);
                }
    
            }
        }
    }
  • 相关阅读:
    spring注解-事务
    docker 安装
    docker 简单介绍
    jupyter配置
    docker 桌面镜像内安装gui程序启动报错
    Linux下安装matlab
    拉取cmake镜像并测试
    桌面镜像安装gui程序
    docker + pycharm 运行
    docker + vscode 运行
  • 原文地址:https://www.cnblogs.com/chenyishi/p/8962753.html
Copyright © 2011-2022 走看看