| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319 | using MySqlConnector;using Newtonsoft.Json.Linq;using System;using System.Collections.Generic;using System.Data;using System.Data.Common;using System.Linq;using System.Text;using System.Threading.Tasks;namespace SqlSugar{    public class MySqlProvider : AdoProvider    {        public MySqlProvider() { }        public override IDbConnection Connection        {            get            {                if (base._DbConnection == null)                {                    try                    {                        var mySqlConnectionString = base.Context.CurrentConnectionConfig.ConnectionString;                        Check.ExceptionEasy(String.IsNullOrEmpty(mySqlConnectionString), "ConnectionString is not null", "连接字符串ConnectionString不能为Null");                        if (!mySqlConnectionString.ToLower().Contains("charset")&& !mySqlConnectionString.ToLower().Contains("character"))                        {                            mySqlConnectionString = mySqlConnectionString.Trim().TrimEnd(';') + ";charset=utf8;";                        }                        //if (!mySqlConnectionString.ToLower().Contains("min"))                        //{                        //    mySqlConnectionString = mySqlConnectionString.Trim().TrimEnd(';') + ";min pool size=1";                        //}                        base._DbConnection = new MySqlConnection(mySqlConnectionString);                    }                    catch (Exception ex)                    {                        if (ex is SqlSugarException)                        {                            throw ex;                        }                        else                        {                            Check.Exception(true, ErrorMessage.ConnnectionOpen, ex.Message);                        }                    }                }                return base._DbConnection;            }            set            {                base._DbConnection = value;            }        }        public override void BeginTran(string transactionName)        {            base.BeginTran();        }        /// <summary>        /// Only SqlServer        /// </summary>        /// <param name="iso"></param>        /// <param name="transactionName"></param>        public override void BeginTran(IsolationLevel iso, string transactionName)        {            base.BeginTran(iso);        }        public override IDataAdapter GetAdapter()        {            return new MySqlDataAdapter();        }        public override DbCommand GetCommand(string sql, SugarParameter[] parameters)        {            MySqlCommand sqlCommand = new MySqlCommand(sql, (MySqlConnection)this.Connection);            sqlCommand.CommandType = this.CommandType;            sqlCommand.CommandTimeout = this.CommandTimeOut;            if (this.Transaction != null)            {                sqlCommand.Transaction = (MySqlTransaction)this.Transaction;            }            if (parameters.HasValue())            {                IDataParameter[] ipars = ToIDbDataParameter(parameters);                sqlCommand.Parameters.AddRange((MySqlParameter[])ipars);            }            CheckConnection();            return sqlCommand;        }        public override void SetCommandToAdapter(IDataAdapter dataAdapter, DbCommand command)        {            ((MySqlDataAdapter)dataAdapter).SelectCommand = (MySqlCommand)command;        }        /// <summary>        /// if mysql return MySqlParameter[] pars        /// if sqlerver return SqlParameter[] pars ...        /// </summary>        /// <param name="parameters"></param>        /// <returns></returns>        public override IDataParameter[] ToIDbDataParameter(params SugarParameter[] parameters)        {            if (parameters == null || parameters.Length == 0) return null;            MySqlParameter[] result = new MySqlParameter[parameters.Length];            int index = 0;            var isVarchar = this.Context.IsVarchar();            foreach (var parameter in parameters)            {                if (parameter.Value == null) parameter.Value = DBNull.Value;                var sqlParameter = new MySqlParameter();                sqlParameter.ParameterName = parameter.ParameterName;                sqlParameter.Size = parameter.Size;                sqlParameter.Value = parameter.Value;                sqlParameter.DbType = parameter.DbType;                if (parameter.Direction == 0)                {                    parameter.Direction = ParameterDirection.Input;                 }                sqlParameter.Direction = parameter.Direction;                //if (sqlParameter.Direction == 0)                //{                //    sqlParameter.Direction = ParameterDirection.Input;                //}                result[index] = sqlParameter;                if (sqlParameter.Direction.IsIn(ParameterDirection.Output, ParameterDirection.InputOutput, ParameterDirection.ReturnValue))                {                    if (this.OutputParameters == null) this.OutputParameters = new List<IDataParameter>();                    this.OutputParameters.RemoveAll(it => it.ParameterName == sqlParameter.ParameterName);                    this.OutputParameters.Add(sqlParameter);                }                if (isVarchar && sqlParameter.DbType == System.Data.DbType.String)                {                    sqlParameter.DbType = System.Data.DbType.AnsiString;                }                else if (parameter.DbType== System.Data.DbType.DateTimeOffset)                 {                    if(sqlParameter.Value != DBNull.Value)                       sqlParameter.Value = UtilMethods.ConvertFromDateTimeOffset((DateTimeOffset)sqlParameter.Value);                    sqlParameter.DbType = System.Data.DbType.DateTime;                }                if (sqlParameter.Value is DateTime&&sqlParameter.Value.ObjToDate()==DateTime.MinValue)                {                    var date = Convert.ToDateTime(sqlParameter.Value);                    if (date == DateTime.MinValue)                    {                        sqlParameter.Value = UtilMethods.GetMinDate(this.Context.CurrentConnectionConfig);                    }                }                if (parameter.IsJson == false&& sqlParameter.Value!=null&& sqlParameter.Value is JArray)                 {                    sqlParameter.Value = sqlParameter.Value.ToString();                }                ++index;            }            return result;        }        protected override void SugarCatch(Exception ex, string sql, SugarParameter[] parameters)        {            base.SugarCatch(ex, sql, parameters);            if (ex is NullReferenceException&&SugarCompatible.IsFramework)             {                Check.ExceptionEasy($"To upgrade the MySql.Data. Error:{ex.Message}", $" 请先升级MySql.Data 。 详细错误:{ex.Message}");            }        }        #region async        public async Task<DbCommand> GetCommandAsync(string sql, SugarParameter[] parameters)        {            MySqlCommand sqlCommand = new MySqlCommand(sql, (MySqlConnection)this.Connection);            sqlCommand.CommandType = this.CommandType;            sqlCommand.CommandTimeout = this.CommandTimeOut;            if (this.Transaction != null)            {                sqlCommand.Transaction = (MySqlTransaction)this.Transaction;            }            if (parameters.HasValue())            {                IDataParameter[] ipars = ToIDbDataParameter(parameters);                sqlCommand.Parameters.AddRange((MySqlParameter[])ipars);            }            if (this.Connection.State != ConnectionState.Open)            {                try                {                    await (this.Connection as MySqlConnection).OpenAsync();                }                catch (Exception ex)                {                    Check.Exception(true, ex.Message);                }            }            return sqlCommand;        }        public override async Task<int> ExecuteCommandAsync(string sql, params SugarParameter[] parameters)        {            if (this.Context.CurrentConnectionConfig?.SqlMiddle?.IsSqlMiddle == true)                return  await base.ExecuteCommandAsync(sql,parameters);            try            {                Async();                InitParameters(ref sql, parameters);                if (FormatSql != null)                    sql = FormatSql(sql);                SetConnectionStart(sql);                if (this.ProcessingEventStartingSQL != null)                    ExecuteProcessingSQL(ref sql, ref parameters);                ExecuteBefore(sql, parameters);                var sqlCommand = await GetCommandAsync(sql, parameters);                int count;                if (this.CancellationToken == null)                    count = await sqlCommand.ExecuteNonQueryAsync();                else                    count = await sqlCommand.ExecuteNonQueryAsync(this.CancellationToken.Value);                if (this.IsClearParameters)                    sqlCommand.Parameters.Clear();                ExecuteAfter(sql, parameters);                sqlCommand.Dispose();                return count;            }            catch (Exception ex)            {                CommandType = CommandType.Text;                if (ErrorEvent != null)                    ExecuteErrorEvent(sql, parameters, ex);                throw ex;            }            finally            {                if (this.IsAutoClose())                {                    await this.CloseAsync();                }                SetConnectionEnd(sql);            }        }        public override async Task<IDataReader> GetDataReaderAsync(string sql, params SugarParameter[] parameters)        {            if (this.Context.CurrentConnectionConfig?.SqlMiddle?.IsSqlMiddle == true)                return await base.GetDataReaderAsync(sql, parameters);            try            {                Async();                InitParameters(ref sql, parameters);                if (FormatSql != null)                    sql = FormatSql(sql);                SetConnectionStart(sql);                var isSp = this.CommandType == CommandType.StoredProcedure;                if (this.ProcessingEventStartingSQL != null)                    ExecuteProcessingSQL(ref sql, ref parameters);                ExecuteBefore(sql, parameters);                var sqlCommand = await GetCommandAsync(sql, parameters);                DbDataReader sqlDataReader;                if (this.CancellationToken == null)                    sqlDataReader = await sqlCommand.ExecuteReaderAsync(this.IsAutoClose() ? CommandBehavior.CloseConnection : CommandBehavior.Default);                else                    sqlDataReader = await sqlCommand.ExecuteReaderAsync(this.IsAutoClose() ? CommandBehavior.CloseConnection : CommandBehavior.Default, this.CancellationToken.Value);                if (isSp)                    DataReaderParameters = sqlCommand.Parameters;                if (this.IsClearParameters)                    sqlCommand.Parameters.Clear();                ExecuteAfter(sql, parameters);                SetConnectionEnd(sql);                if (SugarCompatible.IsFramework || this.Context.CurrentConnectionConfig.DbType != DbType.Sqlite)                    sqlCommand.Dispose();                return sqlDataReader;            }            catch (Exception ex)            {                CommandType = CommandType.Text;                if (ErrorEvent != null)                    ExecuteErrorEvent(sql, parameters, ex);                throw ex;            }        }        public override async Task<object> GetScalarAsync(string sql, params SugarParameter[] parameters)        {            if (this.Context.CurrentConnectionConfig?.SqlMiddle?.IsSqlMiddle == true)                return await base.GetScalarAsync(sql, parameters);            try            {                Async();                InitParameters(ref sql, parameters);                if (FormatSql != null)                    sql = FormatSql(sql);                SetConnectionStart(sql);                if (this.ProcessingEventStartingSQL != null)                    ExecuteProcessingSQL(ref sql, ref parameters);                ExecuteBefore(sql, parameters);                var sqlCommand = await GetCommandAsync(sql, parameters);                object scalar;                if (CancellationToken == null)                    scalar = await sqlCommand.ExecuteScalarAsync();                else                    scalar = await sqlCommand.ExecuteScalarAsync(this.CancellationToken.Value);                //scalar = (scalar == null ? 0 : scalar);                if (this.IsClearParameters)                    sqlCommand.Parameters.Clear();                ExecuteAfter(sql, parameters);                sqlCommand.Dispose();                return scalar;            }            catch (Exception ex)            {                CommandType = CommandType.Text;                if (ErrorEvent != null)                    ExecuteErrorEvent(sql, parameters, ex);                throw ex;            }            finally            {                if (this.IsAutoClose())                {                    await this.CloseAsync();                }                SetConnectionEnd(sql);            }        }        #endregion    }}
 |