C#

21# C# Mysql Connection 라이브러리

NaHyungMin 2019. 5. 23. 16:09

using System;

using System.Collections.Generic;

using System.Data;

using System.Reflection;

using MySql.Data.MySqlClient;

using System.Runtime.CompilerServices;

 

namespace Project.MySql

{

    /// <summary>

    /// MySqlManager의 요약 설명입니다.

    /// </summary>

    public static class MySqlManager

    {

        public static Int32 ExecuteScalar(string connectionString, string procedureName, Dictionary<stringobject> paramsList)

        {

            Int32 resultCode = (Int32)ErrorNumbers.SQL_UNKNOWN_FAILED;

 

            using (MySqlConnection sqlConnection = new MySqlConnection(connectionString))

            using (MySqlCommand sqlCommand = new MySqlCommand(procedureName, sqlConnection))

            {

                sqlCommand.CommandTimeout = 10;

                sqlCommand.CommandType = CommandType.StoredProcedure;

 

                foreach (KeyValuePair<stringobject> pair in paramsList)

                {

                    sqlCommand.Parameters.AddWithValue(pair.Key, pair.Value);

                }

 

                try

                {

                    sqlConnection.Open();

                    object result = sqlCommand.ExecuteScalar();

                    resultCode = Convert.ToInt32(result);

                }

                catch (Exception ex)

                {

                    resultCode = (Int32)ErrorNumbers.SQL_EXCEPTION;

                    WebServerLogger.Instance.Write(LogTypes.ERROR, 1string.Format("Error ExecuteScalar - ProcedureName : {0}, ex : {1}", procedureName, ex.Message));

                }

            }

 

            return resultCode;

        }

 

        public static void ExecuteNonQuery(string connectionString, string procedureName, Dictionary<stringobject> paramsList, out Int32 resultCode)

        {

            resultCode = (Int32)ErrorNumbers.SQL_UNKNOWN_FAILED;

 

            using (MySqlConnection sqlConnection = new MySqlConnection(connectionString))

            using (MySqlCommand sqlCommand = new MySqlCommand(procedureName, sqlConnection))

            {

                sqlCommand.CommandTimeout = 10;

                sqlCommand.CommandType = CommandType.StoredProcedure;

 

                foreach (KeyValuePair<stringobject> pair in paramsList)

                {

                    sqlCommand.Parameters.AddWithValue(pair.Key, pair.Value);

                }

 

                try

                {

                    sqlConnection.Open();

 

                    if (sqlCommand.ExecuteNonQuery() > 0)

                        resultCode = (Int32)ErrorNumbers.SUCCESS;

                }

                catch (Exception ex)

                {

                    resultCode = (Int32)ErrorNumbers.SQL_EXCEPTION;

                    WebServerLogger.Instance.Write(LogTypes.ERROR, 1string.Format("Error ExecuteNonQuery - ProcedureName : {0}, ex : {1}", procedureName, ex.Message));

                }

            }

        }

 

        public static List<T> ExecuteReader<T>(string connectionString, string procedureName, Dictionary<stringobject> paramsList, out Int32 resultCode) where T : new()

        {

            return ExecuteReader<T>(connectionString, procedureName, paramsList, Selector<T>out resultCode);

        }

 

        private static T Selector<T>(IDataRecord dr) where T : new()

        {

            T obj = new T();

 

            foreach (PropertyInfo prop in obj.GetType().GetProperties())

            {

                if (!object.Equals(dr[prop.Name], DBNull.Value))

                {

                    prop.SetValue(obj, dr[prop.Name], null);

                }

            }

 

            return obj;

        }

 

        public static List<T> ExecuteReader<T>(string connectionString, string procedureName, Dictionary<stringobject> paramsList, Func<IDataRecord, T> selector, out Int32 resultCode) where T : new()

        {

            var items = new List<T>();

            resultCode = (Int32)ErrorNumbers.SQL_UNKNOWN_FAILED;

 

            using (MySqlConnection sqlConnection = new MySqlConnection(connectionString))

            using (MySqlCommand sqlCommand = new MySqlCommand(procedureName, sqlConnection))

            {

                sqlCommand.CommandTimeout = ServiceConfig.REQUEST_DB_TIMEOUT_SECOND;

                sqlCommand.CommandType = CommandType.StoredProcedure;

 

                foreach (KeyValuePair<stringobject> pair in paramsList)

                {

                    sqlCommand.Parameters.AddWithValue(pair.Key, pair.Value);

                }

 

                try

                {

                    sqlConnection.Open();

 

                    using (IDataReader r = sqlCommand.ExecuteReader())

                    {

                        var properties = ShareLib.Cache.StaticType<T>.ObjectType.GetProperties();

                        while (r.Read())

                        {

                            T obj = new T();

 

                            foreach (PropertyInfo prop in properties)

                            {

                                if (!object.Equals(r[prop.Name], DBNull.Value))

                                {

                                    prop.SetValue(obj, r[prop.Name], null);

                                }

                            }

 

                            items.Add(obj);

                        }

 

                        resultCode = (Int32)ErrorNumbers.SUCCESS;

                        return items;

                    }

                }

                catch (Exception ex)

                {

                    resultCode = (Int32)ErrorNumbers.SQL_EXCEPTION;

                    WebServerLogger.Instance.Write(LogTypes.ERROR, 1string.Format("Error List<T> ExecuteReader - ProcedureName : {0}, ex : {1}", procedureName, ex.Message));

                }

            }

 

            return items;

        }

 

        private static readonly Dictionary<stringobject> emptyParameter = new Dictionary<stringobject>(0);

        public static MySqlTable<T> ExecuteMySqlTable<T>(string connectionString, string procedureName, out Int32 resultCode)

        {

            return ExecuteMySqlTableImpl<T>(connectionString, procedureName, emptyParameter, out resultCode);

        }

        public static MySqlTable<T> ExecuteMySqlTable<T>(string connectionString, string procedureName, Dictionary<stringobject> paramsList, out Int32 resultCode)

        {

            return ExecuteMySqlTableImpl<T>(connectionString, procedureName, paramsList, out resultCode);

        }

 

        [MethodImpl(MethodImplOptions.AggressiveInlining)]

        private static MySqlTable<T> ExecuteMySqlTableImpl<T>(string connectionString, string procedureName, Dictionary<stringobject> paramsList, out Int32 resultCode)

        {

            MySqlTable<T> mysqlTable = new MySqlTable<T>();

            resultCode = (Int32)ErrorNumbers.SQL_UNKNOWN_FAILED;

 

            using (MySqlConnection sqlConnection = new MySqlConnection(connectionString))

            using (MySqlCommand sqlCommand = new MySqlCommand(procedureName, sqlConnection))

            {

                sqlCommand.CommandTimeout = ServiceConfig.REQUEST_DB_TIMEOUT_SECOND;

                sqlCommand.CommandType = CommandType.StoredProcedure;

 

                foreach (KeyValuePair<stringobject> pair in paramsList)

                {

                    sqlCommand.Parameters.AddWithValue(pair.Key, pair.Value);

                }

 

                try

                {

                    sqlConnection.Open();

 

                    using (IDataReader r = sqlCommand.ExecuteReader())

                    {

                        if (r.Read())

                            resultCode = (Int32)r.GetInt32(0);

 

                        if (r.NextResult() == true)

                            mysqlTable.CreateTable(r);

                    }

                }

                catch (Exception ex)

                {

                    resultCode = (Int32)ErrorNumbers.SQL_EXCEPTION;

                    WebServerLogger.Instance.Write(LogTypes.ERROR, 1string.Format("Error List<T> ExecuteReader - ProcedureName : {0}, ex : {1}", procedureName, ex.Message));

                }

            }

 

            return mysqlTable;

        }

 

        public static List<MySqlTable<T>> ExecuteMySqlTableList<T>(string connectionString, string procedureName, Dictionary<stringobject> paramsList, out Int32 resultCode)

        {

            List<MySqlTable<T>> mysqlTableList = new List<MySqlTable<T>>();

            resultCode = (Int32)ErrorNumbers.SQL_UNKNOWN_FAILED;

 

            using (MySqlConnection sqlConnection = new MySqlConnection(connectionString))

            using (MySqlCommand sqlCommand = new MySqlCommand(procedureName, sqlConnection))

            {

                sqlCommand.CommandTimeout = ServiceConfig.REQUEST_DB_TIMEOUT_SECOND;

                sqlCommand.CommandType = CommandType.StoredProcedure;

 

                foreach (KeyValuePair<stringobject> pair in paramsList)

                {

                    sqlCommand.Parameters.AddWithValue(pair.Key, pair.Value);

                }

 

                try

                {

                    sqlConnection.Open();

 

                    using (IDataReader r = sqlCommand.ExecuteReader())

                    {

                        if (r.Read())

                            resultCode = (Int32)r.GetInt32(0);

 

                        while (r.NextResult() == true)

                        {

                            MySqlTable<T> mysqlTable = new MySqlTable<T>();

                            mysqlTable.CreateTable(r);

 

                            mysqlTableList.Add(mysqlTable);

                        }

                    }

                }

                catch (Exception ex)

                {

                    resultCode = (Int32)ErrorNumbers.SQL_EXCEPTION;

                    WebServerLogger.Instance.Write(LogTypes.ERROR, 1string.Format("Error List<T> ExecuteReader - ProcedureName : {0}, ex : {1}", procedureName, ex.Message));

                }

            }

 

            return mysqlTableList;

        }

    }

}

 

MySqlManager.cs

 

using System;

using System.Collections.Generic;

using System.Data;

 

namespace Project.MySql

{

    public class MySqlTable<T>

    {

        public List<string> Columns

        {

            get;

            set;

        }

 

        public string AddColumn

        {

            set

            {

                if (Columns.Contains(value) == true)

                    new ArgumentException("이미 등록된 컬럼값 입니다.");

 

                Columns.Add(value);

            }

        }

 

        public List<List<T>> Rows

        {

            get;

            set;

        }

 

        public Int32 Count

        {

            get

            {

                return Rows.Count;

            }

        }

 

        public T this[int index]

        {

            get

            {

                return Rows[0][index];

            }

        }

 

        public T this[int row, int index]

        {

            get

            {

                return Rows[row][index];

            }

        }

 

        public T this[int row, string name]

        {

            get

            {

                Int32 index = Columns.FindIndex(t => t == name);

 

                if (index == -1)

                    new ArgumentException("해당 Column이 존재하지 않습니다.");

 

                return Rows[row][index];

            }

        }

 

        public MySqlTable()

        {

            Columns = new List<string>();

            Rows = new List<List<T>>();

        }

 

        public void CreateTable(IDataReader reader)

        {

            try

            {

                Columns = new List<string>(reader.FieldCount);

 

                for (int i = 0; i < reader.FieldCount; i++)

                {

                    AddColumn = reader.GetName(i);

                }

 

                while (reader.Read())

                {

                    List<T> row = new List<T>(Columns.Count);

 

                    for (int i = 0; i < Columns.Count; i++)

                    {

                        if (reader.GetValue(i) == DBNull.Value)

                            row.Add(default(T));

                        else

                            row.Add((T)reader.GetValue(i));

                    }

 

                    Rows.Add(row);

                }

            }

            catch (Exception ex)

            {

                new DataException("CreateTable : " + ex.Message);

                //new ArgumentException("해당 Column이 존재하지 않습니다.");

            }

        }

    }

}

 

MySqlTable.cs

 

 

 

MySqlTable<object> readerList = MySqlManager.ExecuteMySqlTable<object>(ServiceConfig.db_ConnectionString, MySqlProcedureName.sp_BuyShopStar, paramList, out Int32 resultCode);

 

 Int32 resultNumber = MySqlManager.ExecuteScalar(ServiceConfig.db_ConnectionString, MySqlProcedureName.sp_AccountDelete, paramList);

 

List<MySqlTable<object>> readerMysqlTableList = MySqlManager.ExecuteMySqlTableList<object>(ServiceConfig.db_readonly_ConnectionString, MySqlProcedureName.sp_UserPostList_r, paramList, out Int32 resultCode);

 

출처는 내 머리 -..-