mirror of
				https://gitee.com/dotnetchina/SqlSugar.git
				synced 2025-10-26 18:59:17 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			254 lines
		
	
	
		
			9.9 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			254 lines
		
	
	
		
			9.9 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| using Dm;
 | |
| using Npgsql;
 | |
| using NpgsqlTypes;
 | |
| using OpenGauss.NET;
 | |
| using OpenGauss.NET.Types;
 | |
| using SqlSugar.GaussDBCore;
 | |
| using SqlSugar.GaussDBCore.Tools;
 | |
| 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.GaussDB
 | |
| {
 | |
|     public class GaussDBProvider : PostgreSQLProvider
 | |
|     {
 | |
|         public override IDbConnection Connection
 | |
|         {
 | |
|             get
 | |
|             {
 | |
|                 if (base._DbConnection == null)
 | |
|                 {
 | |
|                     try
 | |
|                     {
 | |
|                         var npgsqlConnectionString = base.Context.CurrentConnectionConfig.ConnectionString;
 | |
|                         base._DbConnection = new OpenGaussConnection(npgsqlConnectionString);
 | |
|                     }
 | |
|                     catch (Exception ex)
 | |
|                     {
 | |
|                         throw;
 | |
|                     }
 | |
|                 }
 | |
|                 return base._DbConnection;
 | |
|             }
 | |
|             set
 | |
|             {
 | |
|                 base._DbConnection = value;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         //public override void BeginTran(string transactionName)
 | |
|         //{
 | |
|         //    throw new NotImplementedException();
 | |
|         //}
 | |
| 
 | |
|         //public override void BeginTran(IsolationLevel iso, string transactionName)
 | |
|         //{
 | |
|         //    throw new NotImplementedException();
 | |
|         //}
 | |
| 
 | |
|         public override IDataAdapter GetAdapter()
 | |
|         {
 | |
|             return new GaussDBDataAdapter();
 | |
|         }
 | |
| 
 | |
|         public override DbCommand GetCommand(string sql, SugarParameter[] parameters)
 | |
|         {
 | |
|             OpenGaussCommand sqlCommand = new OpenGaussCommand(sql, (OpenGaussConnection)this.Connection);
 | |
|             sqlCommand.CommandType = this.CommandType;
 | |
|             sqlCommand.CommandTimeout = this.CommandTimeOut;
 | |
|             if (this.Transaction != null)
 | |
|             {
 | |
|                 sqlCommand.Transaction = (OpenGaussTransaction)this.Transaction;
 | |
|             }
 | |
|             if (parameters.HasValue())
 | |
|             {
 | |
|                 IDataParameter[] ipars = ToIDbDataParameter(parameters);
 | |
|                 sqlCommand.Parameters.AddRange((OpenGaussParameter[])ipars);
 | |
|             }
 | |
|             CheckConnection();
 | |
|             return sqlCommand;
 | |
|         }
 | |
| 
 | |
|         public override void SetCommandToAdapter(IDataAdapter adapter, DbCommand command)
 | |
|         {
 | |
|             ((GaussDBDataAdapter)adapter).SelectCommand = (OpenGaussCommand)command;
 | |
|         }
 | |
| 
 | |
|         public override IDataParameter[] ToIDbDataParameter(params SugarParameter[] parameters)
 | |
|         {
 | |
|             if (parameters == null || parameters.Length == 0) return null;
 | |
|             OpenGaussParameter[] result = new OpenGaussParameter[parameters.Length];
 | |
|             int index = 0;
 | |
|             var isVarchar = this.Context.IsVarchar();
 | |
|             foreach (var parameter in parameters)
 | |
|             {
 | |
|                 if (parameter.DbType == System.Data.DbType.Int64 && parameter.Value?.Equals("Result%") == true)
 | |
|                 {
 | |
|                     parameter.DbType = System.Data.DbType.AnsiString;
 | |
|                 }
 | |
|                 UNumber(parameter);
 | |
|                 if (parameter.Value == null) parameter.Value = DBNull.Value;
 | |
|                 if (parameter.Value is System.Data.SqlTypes.SqlDateTime && parameter.DbType == System.Data.DbType.AnsiString)
 | |
|                 {
 | |
|                     parameter.DbType = System.Data.DbType.DateTime;
 | |
|                     parameter.Value = DBNull.Value;
 | |
|                 }
 | |
|                 var sqlParameter = new OpenGaussParameter();
 | |
|                 sqlParameter.ParameterName = parameter.ParameterName;
 | |
|                 sqlParameter.Size = parameter.Size;
 | |
|                 sqlParameter.Value = parameter.Value;
 | |
|                 sqlParameter.DbType = parameter.DbType;
 | |
|                 sqlParameter.Direction = parameter.Direction;
 | |
|                 if (parameter.IsJson)
 | |
|                 {
 | |
|                     sqlParameter.OpenGaussDbType = OpenGaussDbType.Json;
 | |
|                 }
 | |
|                 if (parameter.IsArray)
 | |
|                 {
 | |
|                     Array(parameter, sqlParameter);
 | |
|                 }
 | |
|                 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 (sqlParameter.Value is DateTime && sqlParameter.DbType == System.Data.DbType.AnsiString)
 | |
|                 {
 | |
|                     sqlParameter.DbType = System.Data.DbType.DateTime;
 | |
|                 }
 | |
|                 ++index;
 | |
|                 if (parameter.CustomDbType != null && parameter.CustomDbType is OpenGaussDbType)
 | |
|                 {
 | |
|                     sqlParameter.OpenGaussDbType = ((OpenGaussDbType)parameter.CustomDbType);
 | |
|                 }
 | |
|             }
 | |
|             return result;
 | |
|         }
 | |
| 
 | |
|         private static void Array(SugarParameter parameter, OpenGaussParameter sqlParameter)
 | |
|         {
 | |
|             //    sqlParameter.Value = this.Context.Utilities.SerializeObject(sqlParameter.Value);
 | |
|             var type = sqlParameter.Value.GetType();
 | |
|             if (ArrayMapping.ContainsKey(type))
 | |
|             {
 | |
|                 sqlParameter.OpenGaussDbType = ArrayMapping[type] | OpenGaussDbType.Array;
 | |
|             }
 | |
|             else if (type == DBNull.Value.GetType())
 | |
|             {
 | |
|                 DbNullParametrerArray(parameter, sqlParameter);
 | |
| 
 | |
|             }
 | |
|             else
 | |
|             {
 | |
|                 Check.Exception(true, sqlParameter.Value.GetType().Name + " No Support");
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         private static void DbNullParametrerArray(SugarParameter parameter, OpenGaussParameter sqlParameter)
 | |
|         {
 | |
|             if (parameter.DbType.IsIn(System.Data.DbType.Int32))
 | |
|             {
 | |
|                 sqlParameter.OpenGaussDbType = OpenGaussDbType.Integer | OpenGaussDbType.Array;
 | |
|             }
 | |
|             else if (parameter.DbType.IsIn(System.Data.DbType.Int16))
 | |
|             {
 | |
|                 sqlParameter.OpenGaussDbType = OpenGaussDbType.Smallint | OpenGaussDbType.Array;
 | |
|             }
 | |
|             else if (parameter.DbType.IsIn(System.Data.DbType.Int64))
 | |
|             {
 | |
|                 sqlParameter.OpenGaussDbType = OpenGaussDbType.Bigint | OpenGaussDbType.Array;
 | |
|             }
 | |
|             else if (parameter.DbType.IsIn(System.Data.DbType.Guid))
 | |
|             {
 | |
|                 sqlParameter.OpenGaussDbType = OpenGaussDbType.Uuid | OpenGaussDbType.Array;
 | |
|             }
 | |
|             else
 | |
|             {
 | |
|                 sqlParameter.OpenGaussDbType = OpenGaussDbType.Text | OpenGaussDbType.Array;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         private static void UNumber(SugarParameter parameter)
 | |
|         {
 | |
|             if (parameter.DbType == System.Data.DbType.UInt16)
 | |
|             {
 | |
|                 parameter.DbType = System.Data.DbType.Int16;
 | |
|                 parameter.Value = Convert.ToInt16(parameter.Value);
 | |
|             }
 | |
|             else if (parameter.DbType == System.Data.DbType.UInt32)
 | |
|             {
 | |
|                 parameter.DbType = System.Data.DbType.Int32;
 | |
|                 parameter.Value = Convert.ToInt32(parameter.Value);
 | |
|             }
 | |
|             else if (parameter.DbType == System.Data.DbType.UInt64)
 | |
|             {
 | |
|                 parameter.DbType = System.Data.DbType.Int64;
 | |
|                 parameter.Value = Convert.ToInt64(parameter.Value);
 | |
|             }
 | |
|             if (parameter.Value is uint)
 | |
|             {
 | |
|                 parameter.Value = Convert.ToInt32(parameter.Value);
 | |
|             }
 | |
|             else if (parameter.Value is ulong)
 | |
|             {
 | |
|                 parameter.Value = Convert.ToInt64(parameter.Value);
 | |
|             }
 | |
|         }
 | |
|         public override Action<SqlSugarException> ErrorEvent => it =>
 | |
|         {
 | |
|             if (base.ErrorEvent != null)
 | |
|             {
 | |
|                 base.ErrorEvent(it);
 | |
|             }
 | |
|             if (it.Message != null && it.Message.StartsWith("42883: function uuid_generate_v4() does not exist"))
 | |
|             {
 | |
|                 Check.ExceptionEasy(it.Message, $"使用uuid_generate_v4()函数需要创建 CREATE EXTENSION IF NOT EXISTS pgcrypto;CREATE EXTENSION IF NOT EXISTS \"uuid-ossp\" ");
 | |
|             }
 | |
|         };
 | |
| 
 | |
|         static readonly Dictionary<Type, OpenGaussDbType> ArrayMapping = new Dictionary<Type, OpenGaussDbType>()
 | |
|         {
 | |
|             { typeof(int[]),OpenGaussDbType.Integer},
 | |
|             { typeof(short[]),OpenGaussDbType.Smallint},
 | |
|             { typeof(long[]),OpenGaussDbType.Bigint},
 | |
|             { typeof(decimal[]),OpenGaussDbType.Numeric},
 | |
|             { typeof(char[]),OpenGaussDbType.Text},
 | |
|             { typeof(byte[]),OpenGaussDbType.Bytea},
 | |
|             { typeof(bool[]),OpenGaussDbType.Boolean},
 | |
|             {typeof(DateTime[]),OpenGaussDbType.Date},
 | |
|             {typeof(float[]),OpenGaussDbType.Real},
 | |
|             {typeof(Guid[]),OpenGaussDbType.Uuid},
 | |
| 
 | |
| 
 | |
|             { typeof(int?[]),OpenGaussDbType.Integer},
 | |
|             { typeof(short?[]),OpenGaussDbType.Smallint},
 | |
|             { typeof(long?[]),OpenGaussDbType.Bigint},
 | |
|             { typeof(decimal?[]),OpenGaussDbType.Numeric},
 | |
|             { typeof(char?[]),OpenGaussDbType.Text},
 | |
|             { typeof(byte?[]),OpenGaussDbType.Bytea},
 | |
|             { typeof(bool?[]),OpenGaussDbType.Boolean},
 | |
|             {typeof(DateTime?[]),OpenGaussDbType.Date},
 | |
|             {typeof(Guid?[]),OpenGaussDbType.Uuid},
 | |
| 
 | |
| 
 | |
|              { typeof(string[]), OpenGaussDbType.Text},
 | |
|              {typeof(float?[]),OpenGaussDbType.Real},
 | |
|         };
 | |
|     }
 | |
| }
 | 
