mirror of
				https://gitee.com/dotnetchina/SqlSugar.git
				synced 2025-10-25 02:09:12 +08:00 
			
		
		
		
	*增加TDSQLForPGODBC的支持
This commit is contained in:
		| @@ -0,0 +1,157 @@ | ||||
| using System; | ||||
| using System.Collections.Generic; | ||||
| using System.Data; | ||||
| using System.Data.Odbc; | ||||
| using System.Text; | ||||
| namespace SqlSugar.TDSQLForPGODBC | ||||
| { | ||||
|     /// <summary> | ||||
|     /// 数据填充器 | ||||
|     /// </summary> | ||||
|     public class TDSQLForPGODBCAdapter : IDataAdapter | ||||
|     { | ||||
|         private OdbcCommand command; | ||||
|         private string sql; | ||||
|         private OdbcConnection _sqlConnection; | ||||
|  | ||||
|         /// <summary> | ||||
|         /// SqlDataAdapter | ||||
|         /// </summary> | ||||
|         /// <param name="command"></param> | ||||
|         public TDSQLForPGODBCAdapter(OdbcCommand command) | ||||
|         { | ||||
|             this.command = command; | ||||
|         } | ||||
|  | ||||
|         public TDSQLForPGODBCAdapter() | ||||
|         { | ||||
|  | ||||
|         } | ||||
|  | ||||
|         /// <summary> | ||||
|         /// SqlDataAdapter | ||||
|         /// </summary> | ||||
|         /// <param name="sql"></param> | ||||
|         /// <param name="_sqlConnection"></param> | ||||
|         public TDSQLForPGODBCAdapter(string sql, OdbcConnection _sqlConnection) | ||||
|         { | ||||
|             this.sql = sql; | ||||
|             this._sqlConnection = _sqlConnection; | ||||
|         } | ||||
|  | ||||
|         /// <summary> | ||||
|         /// SelectCommand | ||||
|         /// </summary> | ||||
|         public OdbcCommand SelectCommand | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 if (this.command == null) | ||||
|                 { | ||||
|                     var conn = (OdbcConnection)this._sqlConnection; | ||||
|                     this.command = conn.CreateCommand(); | ||||
|                     this.command.CommandText = sql; | ||||
|                 } | ||||
|                 return this.command; | ||||
|             } | ||||
|             set | ||||
|             { | ||||
|                 this.command = value; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Fill | ||||
|         /// </summary> | ||||
|         /// <param name="dt"></param> | ||||
|         public void Fill(DataTable dt) | ||||
|         { | ||||
|             if (dt == null) | ||||
|             { | ||||
|                 dt = new DataTable(); | ||||
|             } | ||||
|             var columns = dt.Columns; | ||||
|             var rows = dt.Rows; | ||||
|             using (var dr = command.ExecuteReader()) | ||||
|             { | ||||
|                 for (int i = 0; i < dr.FieldCount; i++) | ||||
|                 { | ||||
|                     string name = dr.GetName(i).Trim(); | ||||
|                     if (!columns.Contains(name)) | ||||
|                         columns.Add(new DataColumn(name, dr.GetFieldType(i))); | ||||
|                     else | ||||
|                     { | ||||
|                         columns.Add(new DataColumn(name + i, dr.GetFieldType(i))); | ||||
|                     } | ||||
|                 } | ||||
|  | ||||
|                 while (dr.Read()) | ||||
|                 { | ||||
|                     DataRow daRow = dt.NewRow(); | ||||
|                     for (int i = 0; i < columns.Count; i++) | ||||
|                     { | ||||
|                         daRow[columns[i].ColumnName] = dr.GetValue(i); | ||||
|                     } | ||||
|                     dt.Rows.Add(daRow); | ||||
|                 } | ||||
|             } | ||||
|             dt.AcceptChanges(); | ||||
|         } | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Fill | ||||
|         /// </summary> | ||||
|         /// <param name="ds"></param> | ||||
|         public void Fill(DataSet ds) | ||||
|         { | ||||
|             if (ds == null) | ||||
|             { | ||||
|                 ds = new DataSet(); | ||||
|             } | ||||
|             using (var dr = command.ExecuteReader()) | ||||
|             { | ||||
|                 do | ||||
|                 { | ||||
|                     var dt = new DataTable(); | ||||
|                     var columns = dt.Columns; | ||||
|                     var rows = dt.Rows; | ||||
|                     for (int i = 0; i < dr.FieldCount; i++) | ||||
|                     { | ||||
|                         string name = dr.GetName(i).Trim(); | ||||
|                         if (dr.GetFieldType(i).Name == "DateTime") | ||||
|                         { | ||||
|                             if (!columns.Contains(name)) | ||||
|                                 columns.Add(new DataColumn(name, UtilConstants.DateType)); | ||||
|                             else | ||||
|                             { | ||||
|                                 columns.Add(new DataColumn(name + i, UtilConstants.DateType)); | ||||
|                             } | ||||
|                         } | ||||
|                         else | ||||
|                         { | ||||
|                             if (!columns.Contains(name)) | ||||
|                                 columns.Add(new DataColumn(name, dr.GetFieldType(i))); | ||||
|                             else | ||||
|                             { | ||||
|                                 columns.Add(new DataColumn(name + i, dr.GetFieldType(i))); | ||||
|                             } | ||||
|                         } | ||||
|                     } | ||||
|  | ||||
|                     while (dr.Read()) | ||||
|                     { | ||||
|                         DataRow daRow = dt.NewRow(); | ||||
|                         for (int i = 0; i < columns.Count; i++) | ||||
|                         { | ||||
|                             daRow[columns[i].ColumnName] = dr.GetValue(i); | ||||
|                         } | ||||
|                         dt.Rows.Add(daRow); | ||||
|                     } | ||||
|                     dt.AcceptChanges(); | ||||
|                     ds.Tables.Add(dt); | ||||
|                 } while (dr.NextResult()); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
| } | ||||
| @@ -0,0 +1,13 @@ | ||||
| <Project Sdk="Microsoft.NET.Sdk"> | ||||
|  | ||||
| 	<PropertyGroup> | ||||
| 		<TargetFramework>netstandard2.1</TargetFramework> | ||||
| 		<Nullable>enable</Nullable> | ||||
| 	</PropertyGroup> | ||||
| 	<ItemGroup> | ||||
| 		<PackageReference Include="System.Data.Odbc" Version="8.0.0" /> | ||||
| 	</ItemGroup> | ||||
| 	<ItemGroup> | ||||
| 		<ProjectReference Include="..\SqlSugar\SqlSugar.csproj" /> | ||||
| 	</ItemGroup> | ||||
| </Project> | ||||
| @@ -0,0 +1,90 @@ | ||||
| using System; | ||||
| using System.Collections.Generic; | ||||
| using System.Linq; | ||||
| using System.Text; | ||||
|  | ||||
| namespace SqlSugar.TDSQLForPGODBC | ||||
| { | ||||
|     public class TDSQLForPGODBCCodeFirst : CodeFirstProvider | ||||
|     { | ||||
|         protected override void ExistLogicEnd(List<EntityColumnInfo> dbColumns) | ||||
|         { | ||||
|             foreach (EntityColumnInfo column in dbColumns)  | ||||
|             { | ||||
|                 if (column.DefaultValue != null)  | ||||
|                 { | ||||
|                     this.Context.DbMaintenance.AddDefaultValue(column.DbTableName,column.DbColumnName,column.DefaultValue.ToSqlValue()); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         public override void NoExistLogic(EntityInfo entityInfo) | ||||
|         { | ||||
|             var tableName = GetTableName(entityInfo); | ||||
|             //Check.Exception(entityInfo.Columns.Where(it => it.IsPrimarykey).Count() > 1, "Use Code First ,The primary key must not exceed 1"); | ||||
|             List<DbColumnInfo> columns = new List<DbColumnInfo>(); | ||||
|             if (entityInfo.Columns.HasValue()) | ||||
|             { | ||||
|                 foreach (var item in entityInfo.Columns.Where(it=>it.IsIgnore==false)) | ||||
|                 { | ||||
|                     DbColumnInfo dbColumnInfo = this.EntityColumnToDbColumn(entityInfo, tableName, item); | ||||
|                     columns.Add(dbColumnInfo); | ||||
|                 } | ||||
|                 if (entityInfo.IsCreateTableFiledSort) | ||||
|                 { | ||||
|                     columns = columns.OrderBy(c => c.CreateTableFieldSort).ToList(); | ||||
|                 } | ||||
|             } | ||||
|             columns = columns.OrderBy(it => it.IsPrimarykey ? 0 : 1).ToList(); | ||||
|             this.Context.DbMaintenance.CreateTable(tableName, columns,true); | ||||
|         } | ||||
|         protected override DbColumnInfo EntityColumnToDbColumn(EntityInfo entityInfo, string tableName, EntityColumnInfo item) | ||||
|         { | ||||
|             var propertyType = UtilMethods.GetUnderType(item.PropertyInfo); | ||||
|             var result = new DbColumnInfo() | ||||
|             { | ||||
|                 TableId = entityInfo.Columns.IndexOf(item), | ||||
|                 DbColumnName = item.DbColumnName.HasValue() ? item.DbColumnName : item.PropertyName, | ||||
|                 IsPrimarykey = item.IsPrimarykey, | ||||
|                 IsIdentity = item.IsIdentity, | ||||
|                 TableName = tableName, | ||||
|                 IsNullable = item.IsNullable, | ||||
|                 DefaultValue = item.DefaultValue, | ||||
|                 ColumnDescription = item.ColumnDescription, | ||||
|                 Length = item.Length, | ||||
|                 CreateTableFieldSort = item.CreateTableFieldSort | ||||
|             }; | ||||
|             if (propertyType == UtilConstants.DecType)  | ||||
|             { | ||||
|                 result.Scale = item.DecimalDigits; | ||||
|                 result.DecimalDigits = item.DecimalDigits; | ||||
|             } | ||||
|             GetDbType(item, propertyType, result); | ||||
|             if (result.DataType.Equals("varchar", StringComparison.CurrentCultureIgnoreCase) && result.Length == 0) | ||||
|             { | ||||
|                 result.Length = 1; | ||||
|             } | ||||
|             return result; | ||||
|         } | ||||
|  | ||||
|         protected override void ConvertColumns(List<DbColumnInfo> dbColumns) | ||||
|         { | ||||
|             foreach (var item in dbColumns) | ||||
|             { | ||||
|                 if (item.DataType == "DateTime") | ||||
|                 { | ||||
|                     item.Length = 0; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         protected override void ChangeKey(EntityInfo entityInfo, string tableName, EntityColumnInfo item) | ||||
|         { | ||||
|             this.Context.DbMaintenance.UpdateColumn(tableName, EntityColumnToDbColumn(entityInfo, tableName, item)); | ||||
|             if (!item.IsPrimarykey) | ||||
|                 this.Context.DbMaintenance.DropConstraint(tableName,null); | ||||
|             if (item.IsPrimarykey) | ||||
|                 this.Context.DbMaintenance.AddPrimaryKey(tableName, item.DbColumnName); | ||||
|         } | ||||
|  | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,158 @@ | ||||
| using System; | ||||
| using System.Collections.Generic; | ||||
| using System.Linq; | ||||
|  | ||||
| namespace SqlSugar.TDSQLForPGODBC | ||||
| { | ||||
|     public class TDSQLForPGODBCDbBind : DbBindProvider | ||||
|     { | ||||
|         public override string GetDbTypeName(string csharpTypeName) | ||||
|         { | ||||
|             if (csharpTypeName == UtilConstants.ByteArrayType.Name) | ||||
|                 return "bytea"; | ||||
|             if (csharpTypeName.ToLower() == "int32") | ||||
|                 csharpTypeName = "int"; | ||||
|             if (csharpTypeName.ToLower() == "int16") | ||||
|                 csharpTypeName = "short"; | ||||
|             if (csharpTypeName.ToLower() == "int64") | ||||
|                 csharpTypeName = "long"; | ||||
|             if (csharpTypeName.ToLower().IsIn("boolean", "bool")) | ||||
|                 csharpTypeName = "bool"; | ||||
|             if (csharpTypeName == "DateTimeOffset") | ||||
|                 csharpTypeName = "DateTime"; | ||||
|             var mappings = this.MappingTypes.Where(it => it.Value.ToString().Equals(csharpTypeName, StringComparison.CurrentCultureIgnoreCase)).ToList(); | ||||
|             if (mappings != null && mappings.Count > 0) | ||||
|                 return mappings.First().Key; | ||||
|             else | ||||
|                 return "varchar"; | ||||
|         } | ||||
|         public override string GetPropertyTypeName(string dbTypeName) | ||||
|         { | ||||
|             dbTypeName = dbTypeName.ToLower(); | ||||
|             var propertyTypes = MappingTypes.Where(it => it.Value.ToString().ToLower() == dbTypeName || it.Key.ToLower() == dbTypeName); | ||||
|             if (propertyTypes == null) | ||||
|             { | ||||
|                 return "other"; | ||||
|             } | ||||
|             else if (dbTypeName == "xml" || dbTypeName == "string"|| dbTypeName == "jsonb"|| dbTypeName == "json") | ||||
|             { | ||||
|                 return "string"; | ||||
|             }else if (dbTypeName == "bpchar")//数据库char datatype 查询出来的时候是 bpchar | ||||
|             { | ||||
|                 return "char"; | ||||
|             } | ||||
|             if (dbTypeName == "byte[]") | ||||
|             { | ||||
|                 return "byte[]"; | ||||
|             } | ||||
|             else if (propertyTypes == null || propertyTypes.Count() == 0) | ||||
|             { | ||||
|                 if (dbTypeName.StartsWith("_")) | ||||
|                 { | ||||
|                     var dbTypeName2 = dbTypeName.TrimStart('_'); | ||||
|                     return MappingTypes.Where(it => it.Value.ToString().ToLower() == dbTypeName2  || it.Key.ToLower() == dbTypeName2).Select(it => it.Value + "[]").First(); | ||||
|                 } | ||||
|                 Check.ThrowNotSupportedException(string.Format(" \"{0}\" Type NotSupported, DbBindProvider.GetPropertyTypeName error.", dbTypeName)); | ||||
|                 return null; | ||||
|             } | ||||
|             else if (propertyTypes.First().Value == CSharpDataType.byteArray) | ||||
|             { | ||||
|                 return "byte[]"; | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 return propertyTypes.First().Value.ToString(); | ||||
|             } | ||||
|         } | ||||
|         public override List<KeyValuePair<string, CSharpDataType>> MappingTypes | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 var extService = this.Context.CurrentConnectionConfig.ConfigureExternalServices; | ||||
|                 if (extService != null && extService.AppendDataReaderTypeMappings.HasValue()) | ||||
|                 { | ||||
|                     return extService.AppendDataReaderTypeMappings.Union(MappingTypesConst).ToList(); | ||||
|                 } | ||||
|                 else | ||||
|                 { | ||||
|                     return MappingTypesConst; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         public static List<KeyValuePair<string, CSharpDataType>> MappingTypesConst = new List<KeyValuePair<string, CSharpDataType>>(){ | ||||
|  | ||||
|                     new KeyValuePair<string, CSharpDataType>("int2",CSharpDataType.@short), | ||||
|                     //new KeyValuePair<string, CSharpDataType>("int1",CSharpDataType.@byte), | ||||
|                     new KeyValuePair<string, CSharpDataType>("smallint",CSharpDataType.@short), | ||||
|                     new KeyValuePair<string, CSharpDataType>("smallint",CSharpDataType.@byte), | ||||
|                     new KeyValuePair<string, CSharpDataType>("int4",CSharpDataType.@int),  | ||||
|                     new KeyValuePair<string, CSharpDataType>("serial",CSharpDataType.@int), | ||||
|                     new KeyValuePair<string, CSharpDataType>("integer",CSharpDataType.@int), | ||||
|                     new KeyValuePair<string, CSharpDataType>("int8",CSharpDataType.@long), | ||||
|                     new KeyValuePair<string, CSharpDataType>("long",CSharpDataType.@long), | ||||
|                     new KeyValuePair<string, CSharpDataType>("bigint",CSharpDataType.@long), | ||||
|                     new KeyValuePair<string, CSharpDataType>("float4",CSharpDataType.@float), | ||||
|                     new KeyValuePair<string, CSharpDataType>("float4",CSharpDataType.Single), | ||||
|                     new KeyValuePair<string, CSharpDataType>("real",CSharpDataType.@float), | ||||
|                     new KeyValuePair<string, CSharpDataType>("float8",CSharpDataType.@double), | ||||
|                     new KeyValuePair<string, CSharpDataType>("double precision",CSharpDataType.@int), | ||||
|                     new KeyValuePair<string, CSharpDataType>("numeric",CSharpDataType.@decimal), | ||||
|                     new KeyValuePair<string, CSharpDataType>("decimal",CSharpDataType.@decimal), | ||||
|                     new KeyValuePair<string, CSharpDataType>("path",CSharpDataType.@decimal), | ||||
|                     new KeyValuePair<string, CSharpDataType>("point",CSharpDataType.@decimal), | ||||
|                     new KeyValuePair<string, CSharpDataType>("polygon",CSharpDataType.@decimal), | ||||
|  | ||||
|                     new KeyValuePair<string, CSharpDataType>("boolean",CSharpDataType.@bool), | ||||
|                     new KeyValuePair<string, CSharpDataType>("bool",CSharpDataType.@bool), | ||||
|                     new KeyValuePair<string, CSharpDataType>("box",CSharpDataType.@bool), | ||||
|                     new KeyValuePair<string, CSharpDataType>("bytea",CSharpDataType.byteArray), | ||||
|  | ||||
|                     new KeyValuePair<string, CSharpDataType>("varchar",CSharpDataType.@string), | ||||
|                     new KeyValuePair<string, CSharpDataType>("clob",CSharpDataType.@string), | ||||
|                     new KeyValuePair<string, CSharpDataType>("nvarchar2",CSharpDataType.@string), | ||||
|                     new KeyValuePair<string, CSharpDataType>("varchar2",CSharpDataType.@string), | ||||
|                     new KeyValuePair<string, CSharpDataType>("character varying",CSharpDataType.@string), | ||||
|                     new KeyValuePair<string, CSharpDataType>("geometry",CSharpDataType.@string), | ||||
|                     new KeyValuePair<string, CSharpDataType>("name",CSharpDataType.@string), | ||||
|                     new KeyValuePair<string, CSharpDataType>("text",CSharpDataType.@string), | ||||
|                     new KeyValuePair<string, CSharpDataType>("char",CSharpDataType.@string), | ||||
|                     new KeyValuePair<string, CSharpDataType>("character",CSharpDataType.@string), | ||||
|                     new KeyValuePair<string, CSharpDataType>("cidr",CSharpDataType.@string), | ||||
|                     new KeyValuePair<string, CSharpDataType>("circle",CSharpDataType.@string), | ||||
|                     new KeyValuePair<string, CSharpDataType>("tsquery",CSharpDataType.@string), | ||||
|                     new KeyValuePair<string, CSharpDataType>("tsvector",CSharpDataType.@string), | ||||
|                     new KeyValuePair<string, CSharpDataType>("txid_snapshot",CSharpDataType.@string), | ||||
|                     new KeyValuePair<string, CSharpDataType>("uuid",CSharpDataType.Guid), | ||||
|                     new KeyValuePair<string, CSharpDataType>("xml",CSharpDataType.@string), | ||||
|                     new KeyValuePair<string, CSharpDataType>("json",CSharpDataType.@string), | ||||
|  | ||||
|                     new KeyValuePair<string, CSharpDataType>("interval",CSharpDataType.@decimal), | ||||
|                     new KeyValuePair<string, CSharpDataType>("lseg",CSharpDataType.@decimal), | ||||
|                     new KeyValuePair<string, CSharpDataType>("macaddr",CSharpDataType.@decimal), | ||||
|                     new KeyValuePair<string, CSharpDataType>("money",CSharpDataType.@decimal), | ||||
|                     new KeyValuePair<string, CSharpDataType>("timestamp",CSharpDataType.DateTime), | ||||
|                     new KeyValuePair<string, CSharpDataType>("timestamp with time zone",CSharpDataType.DateTime), | ||||
|                     new KeyValuePair<string, CSharpDataType>("timestamptz",CSharpDataType.DateTime), | ||||
|                     new KeyValuePair<string, CSharpDataType>("timestamp without time zone",CSharpDataType.DateTime), | ||||
|                     new KeyValuePair<string, CSharpDataType>("date",CSharpDataType.DateTime), | ||||
|                     new KeyValuePair<string, CSharpDataType>("time",CSharpDataType.DateTime), | ||||
|                     new KeyValuePair<string, CSharpDataType>("time with time zone",CSharpDataType.DateTime), | ||||
|                     new KeyValuePair<string, CSharpDataType>("timetz",CSharpDataType.DateTime), | ||||
|                     new KeyValuePair<string, CSharpDataType>("time without time zone",CSharpDataType.DateTime), | ||||
|  | ||||
|                     new KeyValuePair<string, CSharpDataType>("bit",CSharpDataType.byteArray), | ||||
|                     new KeyValuePair<string, CSharpDataType>("bit varying",CSharpDataType.byteArray), | ||||
|                     new KeyValuePair<string, CSharpDataType>("varbit",CSharpDataType.@byte), | ||||
|                     new KeyValuePair<string, CSharpDataType>("time",CSharpDataType.TimeSpan), | ||||
|                     new KeyValuePair<string, CSharpDataType>("public.geometry",CSharpDataType.@object), | ||||
|                     new KeyValuePair<string, CSharpDataType>("inet",CSharpDataType.@object) | ||||
|                 }; | ||||
|         public override List<string> StringThrow | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return new List<string>() { "int32", "datetime", "decimal", "double", "byte" }; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,11 @@ | ||||
| using System; | ||||
| using System.Collections.Generic; | ||||
| using System.Linq; | ||||
| using System.Text; | ||||
|  | ||||
| namespace SqlSugar.TDSQLForPGODBC | ||||
| { | ||||
|     public class TDSQLForPGODBCDbFirst : DbFirstProvider | ||||
|     { | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,613 @@ | ||||
| using System; | ||||
| using System.Collections.Generic; | ||||
| using System.Linq; | ||||
| using System.Text; | ||||
| using System.Text.RegularExpressions; | ||||
|   | ||||
| namespace SqlSugar.TDSQLForPGODBC | ||||
| { | ||||
|     public class TDSQLForPGODBCDbMaintenance : DbMaintenanceProvider | ||||
|     { | ||||
|         #region DML | ||||
|         protected override string GetDataBaseSql | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return "SELECT datname FROM pg_database"; | ||||
|             } | ||||
|         } | ||||
|         protected override string GetColumnInfosByTableNameSql | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 string schema = GetSchema(); | ||||
|                 string sql = @"select cast (pclass.oid as int4) as TableId,cast(ptables.tablename as varchar) as TableName, | ||||
|                                 pcolumn.column_name as DbColumnName,pcolumn.udt_name as DataType, | ||||
|                                 CASE WHEN pcolumn.numeric_scale >0 THEN pcolumn.numeric_precision ELSE pcolumn.character_maximum_length END   as Length, | ||||
|                                 pcolumn.column_default as DefaultValue, | ||||
|                                 pcolumn.numeric_scale as DecimalDigits, | ||||
|                                 pcolumn.numeric_scale as Scale, | ||||
|                                 col_description(pclass.oid, pcolumn.ordinal_position) as ColumnDescription, | ||||
|                                 case when pkey.colname = pcolumn.column_name | ||||
|                                 then true else false end as IsPrimaryKey, | ||||
|                                 case when pcolumn.column_default like 'nextval%' | ||||
|                                 then true else false end as IsIdentity, | ||||
|                                 case when pcolumn.is_nullable = 'YES' | ||||
|                                 then true else false end as IsNullable | ||||
|                                  from (select * from pg_tables where upper(tablename) = upper('{0}') and schemaname='" + schema + @"') ptables inner join pg_class pclass | ||||
|                                 on ptables.tablename = pclass.relname inner join (SELECT * | ||||
|                                 FROM information_schema.columns where table_schema='" + schema + @"' | ||||
|                                 ) pcolumn on pcolumn.table_name = ptables.tablename and upper(pcolumn.table_name) = upper('{0}') | ||||
|                                 left join ( | ||||
| 	                                select  pg_class.relname,pg_attribute.attname as colname from  | ||||
| 	                                pg_constraint  inner join pg_class  | ||||
| 	                                on pg_constraint.conrelid = pg_class.oid  | ||||
| 	                                inner join pg_attribute on pg_attribute.attrelid = pg_class.oid  | ||||
| 	                                and  pg_attribute.attnum = pg_constraint.conkey[1] | ||||
| 	                                inner join pg_type on pg_type.oid = pg_attribute.atttypid | ||||
| 	                                where pg_constraint.contype='p' | ||||
|                                 ) pkey on pcolumn.table_name = pkey.relname | ||||
|                                 order by table_catalog, table_schema, ordinal_position"; | ||||
|                 return sql; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         protected override string GetTableInfoListSql | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 var schema = GetSchema(); | ||||
|                 return @"select cast(relname as varchar) as Name, | ||||
|                         cast(obj_description(c.oid,'pg_class') as varchar) as Description from pg_class c  | ||||
|                          inner join  | ||||
| 						 pg_namespace n on n.oid = c.relnamespace and nspname='" + schema + @"' | ||||
|                          inner join  | ||||
|                          pg_tables z on z.tablename=c.relname | ||||
|                         where  relkind in('p', 'r') and relname not like 'pg\_%' and relname not like 'sql\_%' and schemaname='" + schema + "' order by relname"; | ||||
|             } | ||||
|         } | ||||
|         protected override string GetViewInfoListSql | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return @"select  table_name as name  from information_schema.views where table_schema  ='" + GetSchema()+"' "; | ||||
|             } | ||||
|         } | ||||
|         #endregion | ||||
|  | ||||
|         #region DDL | ||||
|         protected override string CreateDataBaseSql | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return "CREATE DATABASE {0}"; | ||||
|             } | ||||
|         } | ||||
|         protected override string AddPrimaryKeySql | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return "ALTER TABLE {0} ADD PRIMARY KEY({2}) /*{1}*/"; | ||||
|             } | ||||
|         } | ||||
|         protected override string AddColumnToTableSql | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return "ALTER TABLE {0} ADD COLUMN {1} {2}{3} {4} {5} {6}"; | ||||
|             } | ||||
|         } | ||||
|         protected override string AlterColumnToTableSql | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return "alter table {0} ALTER COLUMN {1} {2}{3} {4} {5} {6}"; | ||||
|             } | ||||
|         } | ||||
|         protected override string BackupDataBaseSql | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return "mysqldump.exe  {0} -uroot -p > {1}  "; | ||||
|             } | ||||
|         } | ||||
|         protected override string CreateTableSql | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return "CREATE TABLE {0}(\r\n{1} $PrimaryKey)"; | ||||
|             } | ||||
|         } | ||||
|         protected override string CreateTableColumn | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return "{0} {1}{2} {3} {4} {5}"; | ||||
|             } | ||||
|         } | ||||
|         protected override string TruncateTableSql | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return "TRUNCATE TABLE {0}"; | ||||
|             } | ||||
|         } | ||||
|         protected override string BackupTableSql | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return "create table {0} as (select * from {1} limit {2} offset 0)"; | ||||
|             } | ||||
|         } | ||||
|         protected override string DropTableSql | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return "DROP TABLE {0}"; | ||||
|             } | ||||
|         } | ||||
|         protected override string DropColumnToTableSql | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return "ALTER TABLE {0} DROP COLUMN {1}"; | ||||
|             } | ||||
|         } | ||||
|         protected override string DropConstraintSql | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return "ALTER TABLE {0} DROP CONSTRAINT {1}"; | ||||
|             } | ||||
|         } | ||||
|         protected override string RenameColumnSql | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return "ALTER TABLE {0} RENAME {1} TO {2}"; | ||||
|             } | ||||
|         } | ||||
|         protected override string AddColumnRemarkSql => "comment on column {1}.{0} is '{2}'"; | ||||
|  | ||||
|         protected override string DeleteColumnRemarkSql => "comment on column {1}.{0} is ''"; | ||||
|  | ||||
|         protected override string IsAnyColumnRemarkSql { get { throw new NotSupportedException(); } } | ||||
|  | ||||
|         protected override string AddTableRemarkSql => "comment on table {0} is '{1}'"; | ||||
|  | ||||
|         protected override string DeleteTableRemarkSql => "comment on table {0} is ''"; | ||||
|  | ||||
|         protected override string IsAnyTableRemarkSql { get { throw new NotSupportedException(); } } | ||||
|  | ||||
|         protected override string RenameTableSql => "alter table  {0} rename to {1}"; | ||||
|  | ||||
|         protected override string CreateIndexSql | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return "CREATE {3} INDEX Index_{0}_{2} ON {0} ({1})"; | ||||
|             } | ||||
|         } | ||||
|         protected override string AddDefaultValueSql | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return "ALTER TABLE {0} ALTER COLUMN {1} SET DEFAULT {2}"; | ||||
|             } | ||||
|         } | ||||
|         protected override string IsAnyIndexSql | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return "  SELECT count(1) WHERE upper('{0}') IN ( SELECT upper(indexname) FROM pg_indexes )"; | ||||
|             } | ||||
|         } | ||||
|         protected override string IsAnyProcedureSql => throw new NotImplementedException(); | ||||
|         #endregion | ||||
|  | ||||
|         #region Check | ||||
|         protected override string CheckSystemTablePermissionsSql | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return "select 1 from information_schema.columns limit 1 offset 0"; | ||||
|             } | ||||
|         } | ||||
|         #endregion | ||||
|  | ||||
|         #region Scattered | ||||
|         protected override string CreateTableNull | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return "DEFAULT NULL"; | ||||
|             } | ||||
|         } | ||||
|         protected override string CreateTableNotNull | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return "NOT NULL"; | ||||
|             } | ||||
|         } | ||||
|         protected override string CreateTablePirmaryKey | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return "PRIMARY KEY"; | ||||
|             } | ||||
|         } | ||||
|         protected override string CreateTableIdentity | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return "serial"; | ||||
|             } | ||||
|         } | ||||
|         #endregion | ||||
|  | ||||
|         #region Methods | ||||
|         public override List<string> GetDbTypes() | ||||
|         { | ||||
|             var result = this.Context.Ado.SqlQuery<string>(@"SELECT DISTINCT data_type | ||||
| FROM information_schema.columns"); | ||||
|             result.Add("varchar"); | ||||
|             result.Add("timestamp"); | ||||
|             result.Add("uuid"); | ||||
|             result.Add("int2"); | ||||
|             result.Add("int4"); | ||||
|             result.Add("int8"); | ||||
|             result.Add("time"); | ||||
|             result.Add("date"); | ||||
|             result.Add("float8"); | ||||
|             result.Add("float4");  | ||||
|             result.Add("json"); | ||||
|             result.Add("jsonp"); | ||||
|             return result.Distinct().ToList(); | ||||
|         } | ||||
|         public override List<string> GetTriggerNames(string tableName) | ||||
|         { | ||||
|             return this.Context.Ado.SqlQuery<string>(@"SELECT tgname | ||||
| FROM pg_trigger | ||||
| WHERE tgrelid = '"+tableName+"'::regclass"); | ||||
|         } | ||||
|         public override List<string> GetFuncList() | ||||
|         { | ||||
|             return this.Context.Ado.SqlQuery<string>(" SELECT routine_name\r\nFROM information_schema.routines\r\nWHERE lower( routine_schema ) = '" + GetSchema().ToLower() + "' AND routine_type = 'FUNCTION' "); | ||||
|         } | ||||
|         public override List<string> GetIndexList(string tableName) | ||||
|         { | ||||
|             var sql = $"SELECT indexname, indexdef FROM pg_indexes WHERE upper(tablename) = upper('{tableName}') AND upper(schemaname) = upper('{GetSchema()}')"; | ||||
|             return this.Context.Ado.SqlQuery<string>(sql); | ||||
|         } | ||||
|         public override List<string> GetProcList(string dbName) | ||||
|         { | ||||
|             var sql = $"SELECT proname FROM pg_proc p JOIN pg_namespace n ON p.pronamespace = n.oid WHERE n.nspname = '{dbName}'"; | ||||
|             return this.Context.Ado.SqlQuery<string>(sql); | ||||
|         } | ||||
|         public override bool AddDefaultValue(string tableName, string columnName, string defaultValue) | ||||
|         { | ||||
|             if (defaultValue?.StartsWith("'")==true&& defaultValue?.EndsWith("'") == true&& defaultValue?.Contains("(") == false | ||||
|                 &&!defaultValue.EqualCase("'current_timestamp'") && !defaultValue.EqualCase("'current_date'"))  | ||||
|             { | ||||
|                 string sql = string.Format(AddDefaultValueSql,this.SqlBuilder.GetTranslationColumnName( tableName), this.SqlBuilder.GetTranslationColumnName(columnName), defaultValue); | ||||
|                 return this.Context.Ado.ExecuteCommand(sql) > 0; | ||||
|             } | ||||
|             else if (defaultValue.EqualCase("current_timestamp") || defaultValue.EqualCase("current_date")) | ||||
|             { | ||||
|                 string sql = string.Format(AddDefaultValueSql, this.SqlBuilder.GetTranslationColumnName(tableName), this.SqlBuilder.GetTranslationColumnName(columnName),   defaultValue ); | ||||
|                 return this.Context.Ado.ExecuteCommand(sql) > 0; | ||||
|             } | ||||
|             else if (defaultValue?.Contains("(") == false | ||||
|          && !defaultValue.EqualCase("'current_timestamp'") && !defaultValue.EqualCase("'current_date'")) | ||||
|             { | ||||
|                 string sql = string.Format(AddDefaultValueSql, this.SqlBuilder.GetTranslationColumnName(tableName), this.SqlBuilder.GetTranslationColumnName(columnName), "'"+defaultValue+"'"); | ||||
|                 return this.Context.Ado.ExecuteCommand(sql) > 0; | ||||
|             } | ||||
|             else if (defaultValue?.ToLower()?.Contains("cast(") == true && defaultValue?.StartsWith("'") == true && defaultValue?.EndsWith("'") == true) | ||||
|             { | ||||
|                 string sql = string.Format(AddDefaultValueSql, this.SqlBuilder.GetTranslationColumnName(tableName), this.SqlBuilder.GetTranslationColumnName(columnName), defaultValue.Replace("''","'").TrimEnd('\'').TrimStart('\'')); | ||||
|                 return this.Context.Ado.ExecuteCommand(sql) > 0; | ||||
|             } | ||||
|             else if (defaultValue?.ToLower()?.Contains("now()") == true) | ||||
|             { | ||||
|                 string sql = string.Format(AddDefaultValueSql, this.SqlBuilder.GetTranslationColumnName(tableName), this.SqlBuilder.GetTranslationColumnName(columnName), defaultValue.TrimEnd('\'').TrimStart('\'')); | ||||
|                 return this.Context.Ado.ExecuteCommand(sql) > 0; | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 return base.AddDefaultValue(this.SqlBuilder.GetTranslationTableName(tableName), this.SqlBuilder.GetTranslationTableName(columnName), defaultValue); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         public override bool RenameTable(string oldTableName, string newTableName) | ||||
|         { | ||||
|             return base.RenameTable(this.SqlBuilder.GetTranslationTableName(oldTableName), this.SqlBuilder.GetTranslationTableName(newTableName)); | ||||
|         } | ||||
|  | ||||
|         public override bool AddColumnRemark(string columnName, string tableName, string description) | ||||
|         { | ||||
|             tableName = this.SqlBuilder.GetTranslationTableName(tableName); | ||||
|             string sql = string.Format(this.AddColumnRemarkSql, this.SqlBuilder.GetTranslationColumnName(columnName.ToLower(isAutoToLowerCodeFirst)), tableName, description); | ||||
|             this.Context.Ado.ExecuteCommand(sql); | ||||
|             return true; | ||||
|         } | ||||
|         public override bool AddTableRemark(string tableName, string description) | ||||
|         { | ||||
|             tableName = this.SqlBuilder.GetTranslationTableName(tableName); | ||||
|             return base.AddTableRemark(tableName, description); | ||||
|         } | ||||
|         public override bool UpdateColumn(string tableName, DbColumnInfo columnInfo) | ||||
|         { | ||||
|             ConvertCreateColumnInfo(columnInfo); | ||||
|             tableName = this.SqlBuilder.GetTranslationTableName(tableName); | ||||
|             var columnName= this.SqlBuilder.GetTranslationColumnName(columnInfo.DbColumnName); | ||||
|             string sql = GetUpdateColumnSql(tableName, columnInfo); | ||||
|             this.Context.Ado.ExecuteCommand(sql); | ||||
|             var isnull = columnInfo.IsNullable?" DROP NOT NULL ": " SET NOT NULL "; | ||||
|             this.Context.Ado.ExecuteCommand(string.Format("alter table {0} alter {1} {2}",tableName,columnName, isnull)); | ||||
|             return true; | ||||
|         } | ||||
|  | ||||
|         protected override string GetUpdateColumnSql(string tableName, DbColumnInfo columnInfo) | ||||
|         { | ||||
|             string columnName = this.SqlBuilder.GetTranslationColumnName(columnInfo.DbColumnName); | ||||
|             tableName = this.SqlBuilder.GetTranslationTableName(tableName); | ||||
|             string dataSize = GetSize(columnInfo); | ||||
|             string dataType = columnInfo.DataType; | ||||
|             if (!string.IsNullOrEmpty(dataType)) | ||||
|             { | ||||
|                 dataType = " type " + dataType; | ||||
|             } | ||||
|             string nullType = ""; | ||||
|             string primaryKey = null; | ||||
|             string identity = null; | ||||
|             string result = string.Format(this.AlterColumnToTableSql, tableName, columnName, dataType, dataSize, nullType, primaryKey, identity); | ||||
|             return result; | ||||
|         } | ||||
|  | ||||
|         /// <summary> | ||||
|         ///by current connection string | ||||
|         /// </summary> | ||||
|         /// <param name="databaseDirectory"></param> | ||||
|         /// <returns></returns> | ||||
|         public override bool CreateDatabase(string databaseName, string databaseDirectory = null) | ||||
|         { | ||||
|             if (databaseDirectory != null) | ||||
|             { | ||||
|                 if (!FileHelper.IsExistDirectory(databaseDirectory)) | ||||
|                 { | ||||
|                     FileHelper.CreateDirectory(databaseDirectory); | ||||
|                 } | ||||
|             } | ||||
|             var oldDatabaseName = this.Context.Ado.Connection.Database; | ||||
|             var connection = this.Context.CurrentConnectionConfig.ConnectionString; | ||||
|             connection = connection.Replace(oldDatabaseName, "postgres"); | ||||
|             var newDb = new SqlSugarClient(new ConnectionConfig() | ||||
|             { | ||||
|                 DbType = this.Context.CurrentConnectionConfig.DbType, | ||||
|                 IsAutoCloseConnection = true, | ||||
|                 ConnectionString = connection | ||||
|             }); | ||||
|             if (!GetDataBaseList(newDb).Any(it => it.Equals(databaseName, StringComparison.CurrentCultureIgnoreCase))) | ||||
|             { | ||||
|                 var isVast = this.Context?.CurrentConnectionConfig?.MoreSettings?.DatabaseModel==DbType.Vastbase; | ||||
|                 var dbcompatibility = ""; | ||||
|                 if (isVast)  | ||||
|                 { | ||||
|                     dbcompatibility=" dbcompatibility = 'PG'"; | ||||
|                 } | ||||
|                 newDb.Ado.ExecuteCommand(string.Format(CreateDataBaseSql, this.SqlBuilder.SqlTranslationLeft+databaseName+this.SqlBuilder.SqlTranslationRight, databaseDirectory)+ dbcompatibility); | ||||
|             } | ||||
|             return true; | ||||
|         } | ||||
|         public override bool AddRemark(EntityInfo entity) | ||||
|         { | ||||
|             var db = this.Context; | ||||
|             var columns = entity.Columns.Where(it => it.IsIgnore == false).ToList(); | ||||
|  | ||||
|             foreach (var item in columns) | ||||
|             { | ||||
|                 if (item.ColumnDescription != null) | ||||
|                 { | ||||
|                     db.DbMaintenance.AddColumnRemark(item.DbColumnName, item.DbTableName, item.ColumnDescription); | ||||
|  | ||||
|                 } | ||||
|             } | ||||
|             //table remak | ||||
|             if (entity.TableDescription != null) | ||||
|             { | ||||
|                 db.DbMaintenance.AddTableRemark(entity.DbTableName, entity.TableDescription); | ||||
|             } | ||||
|             return true; | ||||
|         } | ||||
|         public override bool CreateTable(string tableName, List<DbColumnInfo> columns, bool isCreatePrimaryKey = true) | ||||
|         { | ||||
|             if (columns.HasValue()) | ||||
|             { | ||||
|                 foreach (var item in columns) | ||||
|                 { | ||||
|                     ConvertCreateColumnInfo(item); | ||||
|                     if (item.DbColumnName.Equals("GUID", StringComparison.CurrentCultureIgnoreCase) && item.Length == 0) | ||||
|                     { | ||||
|                         if (item.DataType?.ToLower() != "uuid") | ||||
|                         { | ||||
|                             item.Length = 10; | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|             string sql = GetCreateTableSql(tableName, columns); | ||||
|             string primaryKeyInfo = null; | ||||
|             if (columns.Any(it => it.IsPrimarykey) && isCreatePrimaryKey) | ||||
|             { | ||||
|                 primaryKeyInfo = string.Format(", Primary key({0})", string.Join(",", columns.Where(it => it.IsPrimarykey).Select(it => this.SqlBuilder.GetTranslationColumnName(it.DbColumnName.ToLower(isAutoToLowerCodeFirst))))); | ||||
|  | ||||
|             } | ||||
|             sql = sql.Replace("$PrimaryKey", primaryKeyInfo); | ||||
|             this.Context.Ado.ExecuteCommand(sql); | ||||
|             return true; | ||||
|         } | ||||
|         protected override bool IsAnyDefaultValue(string tableName, string columnName, List<DbColumnInfo> columns) | ||||
|         { | ||||
|             var defaultValue = columns.Where(it => it.DbColumnName.Equals(columnName, StringComparison.CurrentCultureIgnoreCase)).First().DefaultValue; | ||||
|             if (defaultValue?.StartsWith("NULL::") == true)  | ||||
|             { | ||||
|                 return false; | ||||
|             } | ||||
|             return defaultValue.HasValue(); | ||||
|         } | ||||
|         protected override string GetCreateTableSql(string tableName, List<DbColumnInfo> columns) | ||||
|         { | ||||
|             List<string> columnArray = new List<string>(); | ||||
|             Check.Exception(columns.IsNullOrEmpty(), "No columns found "); | ||||
|             foreach (var item in columns) | ||||
|             { | ||||
|                 string columnName = item.DbColumnName; | ||||
|                 string dataType = item.DataType; | ||||
|                 if (dataType == "varchar" && item.Length == 0) | ||||
|                 { | ||||
|                     item.Length = 1; | ||||
|                 } | ||||
|                 //if (dataType == "uuid") | ||||
|                 //{ | ||||
|                 //    item.Length = 50; | ||||
|                 //    dataType = "varchar"; | ||||
|                 //} | ||||
|                 string dataSize = item.Length > 0 ? string.Format("({0})", item.Length) : null; | ||||
|                 if (item.DecimalDigits > 0&&item.Length>0 && dataType == "numeric")  | ||||
|                 { | ||||
|                     dataSize = $"({item.Length},{item.DecimalDigits})"; | ||||
|                 } | ||||
|                 string nullType = item.IsNullable ? this.CreateTableNull : CreateTableNotNull; | ||||
|                 string primaryKey = null; | ||||
|                 string addItem = string.Format(this.CreateTableColumn, this.SqlBuilder.GetTranslationColumnName(columnName.ToLower(isAutoToLowerCodeFirst)), dataType, dataSize, nullType, primaryKey, ""); | ||||
|                 if (item.IsIdentity) | ||||
|                 { | ||||
|                     if (dataType?.ToLower() == "int")  | ||||
|                     { | ||||
|                         dataSize = "int4"; | ||||
|                     } | ||||
|                     else if (dataType?.ToLower() == "long") | ||||
|                     { | ||||
|                         dataSize = "int8"; | ||||
|                     } | ||||
|                     string length = dataType.Substring(dataType.Length - 1); | ||||
|                     string identityDataType = "serial" + length; | ||||
|                     addItem = addItem.Replace(dataType, identityDataType); | ||||
|                 } | ||||
|                 columnArray.Add(addItem); | ||||
|             } | ||||
|             string tableString = string.Format(this.CreateTableSql, this.SqlBuilder.GetTranslationTableName(tableName.ToLower(isAutoToLowerCodeFirst)), string.Join(",\r\n", columnArray)); | ||||
|             return tableString; | ||||
|         } | ||||
|         public override bool IsAnyConstraint(string constraintName) | ||||
|         { | ||||
|             throw new NotSupportedException("PgSql IsAnyConstraint NotSupportedException"); | ||||
|         } | ||||
|         public override bool BackupDataBase(string databaseName, string fullFileName) | ||||
|         { | ||||
|             Check.ThrowNotSupportedException("PgSql BackupDataBase NotSupported"); | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         public override List<DbColumnInfo> GetColumnInfosByTableName(string tableName, bool isCache = true) | ||||
|         { | ||||
|             var result= base.GetColumnInfosByTableName(tableName.TrimEnd('"').TrimStart('"').ToLower(), isCache); | ||||
|             if (result == null || result.Count() == 0) | ||||
|             { | ||||
|                 result = base.GetColumnInfosByTableName(tableName, isCache); | ||||
|             } | ||||
|             try | ||||
|             { | ||||
|                 string sql = $@"select   | ||||
|                                kcu.column_name as key_column | ||||
|                                from information_schema.table_constraints tco | ||||
|                                join information_schema.key_column_usage kcu  | ||||
|                                on kcu.constraint_name = tco.constraint_name | ||||
|                                and kcu.constraint_schema = tco.constraint_schema | ||||
|                                and kcu.constraint_name = tco.constraint_name | ||||
|                                where tco.constraint_type = 'PRIMARY KEY' | ||||
|                                and kcu.table_schema='{GetSchema()}' and  | ||||
|                                upper(kcu.table_name)=upper('{tableName.TrimEnd('"').TrimStart('"')}')"; | ||||
|                 List<string> pkList = new List<string>(); | ||||
|                 if (isCache) | ||||
|                 { | ||||
|                     pkList=GetListOrCache<string>("GetColumnInfosByTableName_N_Pk"+tableName, sql); | ||||
|                 } | ||||
|                 else | ||||
|                 { | ||||
|                     pkList = this.Context.Ado.SqlQuery<string>(sql); | ||||
|                 } | ||||
|                 if (pkList.Count >1)  | ||||
|                 { | ||||
|                     foreach (var item in result) | ||||
|                     { | ||||
|                         if (pkList.Select(it=>it.ToUpper()).Contains(item.DbColumnName.ToUpper()))  | ||||
|                         { | ||||
|                             item.IsPrimarykey = true; | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|             catch   | ||||
|             { | ||||
|  | ||||
|             } | ||||
|             return result; | ||||
|         } | ||||
|         #endregion | ||||
|  | ||||
|         #region Helper | ||||
|         private bool isAutoToLowerCodeFirst | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 if (this.Context.CurrentConnectionConfig.MoreSettings == null) return true; | ||||
|                 else if ( | ||||
|                     this.Context.CurrentConnectionConfig.MoreSettings.PgSqlIsAutoToLower == false && | ||||
|                     this.Context.CurrentConnectionConfig.MoreSettings?.PgSqlIsAutoToLowerCodeFirst == false) | ||||
|                 { | ||||
|                     return false; | ||||
|                 } | ||||
|                 else | ||||
|                 { | ||||
|                     return true; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         private string GetSchema() | ||||
|         { | ||||
|             var schema = "public"; | ||||
|             if (System.Text.RegularExpressions.Regex.IsMatch(this.Context.CurrentConnectionConfig.ConnectionString.ToLower(), "searchpath=")) | ||||
|             { | ||||
|                 var regValue = System.Text.RegularExpressions.Regex.Match(this.Context.CurrentConnectionConfig.ConnectionString.ToLower(), @"searchpath\=(\w+)").Groups[1].Value; | ||||
|                 if (regValue.HasValue()) | ||||
|                 { | ||||
|                     schema = regValue; | ||||
|                 } | ||||
|             } | ||||
|             else if (System.Text.RegularExpressions.Regex.IsMatch(this.Context.CurrentConnectionConfig.ConnectionString.ToLower(), "search path=")) | ||||
|             { | ||||
|                 var regValue = System.Text.RegularExpressions.Regex.Match(this.Context.CurrentConnectionConfig.ConnectionString.ToLower(), @"search path\=(\w+)").Groups[1].Value; | ||||
|                 if (regValue.HasValue()) | ||||
|                 { | ||||
|                     schema = regValue; | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|             return schema; | ||||
|         } | ||||
|         private static void ConvertCreateColumnInfo(DbColumnInfo x) | ||||
|         { | ||||
|             string[] array = new string[] { "uuid","int4", "text", "int2", "int8", "date", "bit", "text", "timestamp" }; | ||||
|  | ||||
|             if (array.Contains(x.DataType?.ToLower())) | ||||
|             { | ||||
|                 x.Length = 0; | ||||
|                 x.DecimalDigits = 0; | ||||
|             } | ||||
|         } | ||||
|         #endregion | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,105 @@ | ||||
| using System; | ||||
| using System.Collections.Generic; | ||||
| using System.Linq; | ||||
| using System.Linq.Expressions; | ||||
| using System.Text; | ||||
| using System.Threading.Tasks; | ||||
|  | ||||
| namespace SqlSugar.TDSQLForPGODBC | ||||
| { | ||||
|     public class TDSQLForPGODBCInserttable<T> : InsertableProvider<T> where T : class, new() | ||||
|     { | ||||
|         public override int ExecuteReturnIdentity() | ||||
|         { | ||||
|             InsertBuilder.IsReturnIdentity = true; | ||||
|             PreToSql(); | ||||
|             string identityColumn = GetIdentityColumn(); | ||||
|             string sql = InsertBuilder.ToSqlString().Replace("$PrimaryKey", this.SqlBuilder.GetTranslationColumnName(identityColumn)); | ||||
|             RestoreMapping(); | ||||
|             AutoRemoveDataCache(); | ||||
|             var result = Ado.GetScalar(sql, InsertBuilder.Parameters == null ? null : InsertBuilder.Parameters.ToArray()).ObjToInt(); | ||||
|             After(sql, result); | ||||
|             return result; | ||||
|         } | ||||
|         public override async Task<int> ExecuteReturnIdentityAsync() | ||||
|         { | ||||
|             InsertBuilder.IsReturnIdentity = true; | ||||
|             PreToSql(); | ||||
|             string identityColumn = GetIdentityColumn(); | ||||
|             string sql = InsertBuilder.ToSqlString().Replace("$PrimaryKey", this.SqlBuilder.GetTranslationColumnName(identityColumn)); | ||||
|             RestoreMapping(); | ||||
|             AutoRemoveDataCache(); | ||||
|             var obj = await Ado.GetScalarAsync(sql, InsertBuilder.Parameters == null ? null : InsertBuilder.Parameters.ToArray()); | ||||
|             var result = obj.ObjToInt(); | ||||
|             After(sql, result); | ||||
|             return result; | ||||
|         } | ||||
|         public override KeyValuePair<string, List<SugarParameter>> ToSql() | ||||
|         { | ||||
|             var result= base.ToSql(); | ||||
|             var primaryKey = GetPrimaryKeys().FirstOrDefault(); | ||||
|             if (primaryKey != null) | ||||
|             { | ||||
|                 primaryKey = this.SqlBuilder.GetTranslationColumnName(primaryKey); | ||||
|             } | ||||
|             else if(result.Key?.EndsWith(" returning $PrimaryKey") ==true) | ||||
|             { | ||||
|                 result=new KeyValuePair<string, List<SugarParameter>>( result.Key.Replace(" returning $PrimaryKey", null),result.Value); | ||||
|             } | ||||
|             return new KeyValuePair<string, List<SugarParameter>>(result.Key.Replace("$PrimaryKey", primaryKey), result.Value); | ||||
|         } | ||||
|  | ||||
|         public override long ExecuteReturnBigIdentity() | ||||
|         { | ||||
|             InsertBuilder.IsReturnIdentity = true; | ||||
|             PreToSql(); | ||||
|             string sql = InsertBuilder.ToSqlString().Replace("$PrimaryKey", this.SqlBuilder.GetTranslationColumnName(GetIdentityKeys().FirstOrDefault())); | ||||
|             RestoreMapping(); | ||||
|             AutoRemoveDataCache(); | ||||
|             var result = Convert.ToInt64(Ado.GetScalar(sql, InsertBuilder.Parameters == null ? null : InsertBuilder.Parameters.ToArray()) ?? "0"); | ||||
|             After(sql, result); | ||||
|             return result; | ||||
|         } | ||||
|         public override async Task<long> ExecuteReturnBigIdentityAsync() | ||||
|         { | ||||
|             InsertBuilder.IsReturnIdentity = true; | ||||
|             PreToSql(); | ||||
|             string sql = InsertBuilder.ToSqlString().Replace("$PrimaryKey", this.SqlBuilder.GetTranslationColumnName(GetIdentityKeys().FirstOrDefault())); | ||||
|             RestoreMapping(); | ||||
|             AutoRemoveDataCache(); | ||||
|             var result = Convert.ToInt64(await Ado.GetScalarAsync(sql, InsertBuilder.Parameters == null ? null : InsertBuilder.Parameters.ToArray()) ?? "0"); | ||||
|             After(sql, result); | ||||
|             return result; | ||||
|         } | ||||
|  | ||||
|         public override bool ExecuteCommandIdentityIntoEntity() | ||||
|         { | ||||
|             var result = InsertObjs.First(); | ||||
|             var identityKeys = GetIdentityKeys(); | ||||
|             if (identityKeys.Count == 0) { return this.ExecuteCommand() > 0; } | ||||
|             var idValue = ExecuteReturnBigIdentity(); | ||||
|             Check.Exception(identityKeys.Count > 1, "ExecuteCommandIdentityIntoEntity does not support multiple identity keys"); | ||||
|             var identityKey = identityKeys.First(); | ||||
|             object setValue = 0; | ||||
|             if (idValue > int.MaxValue) | ||||
|                 setValue = idValue; | ||||
|             else | ||||
|                 setValue = Convert.ToInt32(idValue); | ||||
|             var propertyName = this.Context.EntityMaintenance.GetPropertyName<T>(identityKey); | ||||
|             typeof(T).GetProperties().First(t => t.Name.ToUpper() == propertyName.ToUpper()).SetValue(result, setValue, null); | ||||
|             return idValue > 0; | ||||
|         } | ||||
|  | ||||
|         private string GetIdentityColumn() | ||||
|         { | ||||
|             var identityColumn = GetIdentityKeys().FirstOrDefault(); | ||||
|             if (identityColumn == null) | ||||
|             { | ||||
|                 var columns = this.Context.DbMaintenance.GetColumnInfosByTableName(InsertBuilder.GetTableNameString); | ||||
|                 identityColumn = columns.First(it => it.IsIdentity || it.IsPrimarykey).DbColumnName; | ||||
|             } | ||||
|             return identityColumn; | ||||
|         } | ||||
|  | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,69 @@ | ||||
| using System; | ||||
| using System.Collections.Generic; | ||||
| using System.Linq; | ||||
| using System.Text; | ||||
| using System.Threading.Tasks; | ||||
|  | ||||
| namespace SqlSugar.TDSQLForPGODBC | ||||
| { | ||||
|     public class TDSQLForPGODBCQueryable<T> : QueryableProvider<T> | ||||
|     { | ||||
|         public override ISugarQueryable<T> With(string withString) | ||||
|         { | ||||
|             return this; | ||||
|         } | ||||
|  | ||||
|         public override ISugarQueryable<T> PartitionBy(string groupFileds) | ||||
|         { | ||||
|             this.GroupBy(groupFileds); | ||||
|             return this; | ||||
|         } | ||||
|     } | ||||
|     public class PostgreSQLQueryable<T, T2> : QueryableProvider<T, T2> | ||||
|     { | ||||
|         public new ISugarQueryable<T, T2> With(string withString) | ||||
|         { | ||||
|             return this; | ||||
|         } | ||||
|     } | ||||
|     public class PostgreSQLQueryable<T, T2, T3> : QueryableProvider<T, T2, T3> | ||||
|     { | ||||
|  | ||||
|     } | ||||
|     public class PostgreSQLQueryable<T, T2, T3, T4> : QueryableProvider<T, T2, T3, T4> | ||||
|     { | ||||
|  | ||||
|     } | ||||
|     public class PostgreSQLQueryable<T, T2, T3, T4, T5> : QueryableProvider<T, T2, T3, T4, T5> | ||||
|     { | ||||
|  | ||||
|     } | ||||
|     public class PostgreSQLQueryable<T, T2, T3, T4, T5, T6> : QueryableProvider<T, T2, T3, T4, T5, T6> | ||||
|     { | ||||
|  | ||||
|     } | ||||
|     public class PostgreSQLQueryable<T, T2, T3, T4, T5, T6, T7> : QueryableProvider<T, T2, T3, T4, T5, T6, T7> | ||||
|     { | ||||
|  | ||||
|     } | ||||
|     public class PostgreSQLQueryable<T, T2, T3, T4, T5, T6, T7, T8> : QueryableProvider<T, T2, T3, T4, T5, T6, T7, T8> | ||||
|     { | ||||
|  | ||||
|     } | ||||
|     public class PostgreSQLQueryable<T, T2, T3, T4, T5, T6, T7, T8, T9> : QueryableProvider<T, T2, T3, T4, T5, T6, T7, T8, T9> | ||||
|     { | ||||
|  | ||||
|     } | ||||
|     public class PostgreSQLQueryable<T, T2, T3, T4, T5, T6, T7, T8, T9, T10> : QueryableProvider<T, T2, T3, T4, T5, T6, T7, T8, T9, T10> | ||||
|     { | ||||
|  | ||||
|     } | ||||
|     public class PostgreSQLQueryable<T, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11> : QueryableProvider<T, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11> | ||||
|     { | ||||
|  | ||||
|     } | ||||
|     public class PostgreSQLQueryable<T, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12> : QueryableProvider<T, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12> | ||||
|     { | ||||
|  | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,128 @@ | ||||
| using System; | ||||
| using System.Linq; | ||||
| using System.Text.RegularExpressions; | ||||
|  | ||||
| namespace SqlSugar.TDSQLForPGODBC | ||||
| { | ||||
|     public class TDSQLForPGODBCBuilder : SqlBuilderProvider | ||||
|     { | ||||
|         public override string SqlTranslationLeft | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return "\""; | ||||
|             } | ||||
|         } | ||||
|         public override string SqlTranslationRight | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return "\""; | ||||
|             } | ||||
|         } | ||||
|         public override string SqlDateNow | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return "CURRENT_TIMESTAMP"; | ||||
|             } | ||||
|         } | ||||
|         public override string FullSqlDateNow | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return "select CURRENT_TIMESTAMP"; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         public bool isAutoToLower | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 if (this.Context.CurrentConnectionConfig.MoreSettings == null) return true; | ||||
|                 return this.Context.CurrentConnectionConfig.MoreSettings.PgSqlIsAutoToLower; | ||||
|             } | ||||
|         } | ||||
|         public override string GetTranslationColumnName(string propertyName) | ||||
|         { | ||||
|             if (propertyName.Contains(".")&& !propertyName.Contains(SqlTranslationLeft))  | ||||
|             { | ||||
|                 return string.Join(".", propertyName.Split('.').Select(it => $"{SqlTranslationLeft}{it.ToLower(isAutoToLower)}{SqlTranslationRight}")); | ||||
|             } | ||||
|  | ||||
|             if (propertyName.Contains(SqlTranslationLeft)) return propertyName; | ||||
|             else | ||||
|                 return SqlTranslationLeft + propertyName.ToLower(isAutoToLower) + SqlTranslationRight; | ||||
|         } | ||||
|  | ||||
|         //public override string GetNoTranslationColumnName(string name) | ||||
|         //{ | ||||
|         //    return name.TrimEnd(Convert.ToChar(SqlTranslationRight)).TrimStart(Convert.ToChar(SqlTranslationLeft)).ToLower(); | ||||
|         //} | ||||
|         public override string GetTranslationColumnName(string entityName, string propertyName) | ||||
|         { | ||||
|             Check.ArgumentNullException(entityName, string.Format(ErrorMessage.ObjNotExist, "Table Name")); | ||||
|             Check.ArgumentNullException(propertyName, string.Format(ErrorMessage.ObjNotExist, "Column Name")); | ||||
|             var context = this.Context; | ||||
|             var mappingInfo = context | ||||
|                  .MappingColumns | ||||
|                  .FirstOrDefault(it => | ||||
|                  it.EntityName.Equals(entityName, StringComparison.CurrentCultureIgnoreCase) && | ||||
|                  it.PropertyName.Equals(propertyName, StringComparison.CurrentCultureIgnoreCase)); | ||||
|             return (mappingInfo == null ? SqlTranslationLeft + propertyName.ToLower(isAutoToLower) + SqlTranslationRight : SqlTranslationLeft + mappingInfo.DbColumnName.ToLower(isAutoToLower) + SqlTranslationRight); | ||||
|         } | ||||
|  | ||||
|         public override string GetTranslationTableName(string name) | ||||
|         { | ||||
|             Check.ArgumentNullException(name, string.Format(ErrorMessage.ObjNotExist, "Table Name")); | ||||
|             var context = this.Context; | ||||
|  | ||||
|             var mappingInfo = context | ||||
|                 .MappingTables | ||||
|                 .FirstOrDefault(it => it.EntityName.Equals(name, StringComparison.CurrentCultureIgnoreCase)); | ||||
|             if (mappingInfo == null && name.Contains(".") && name.Contains("\""))  | ||||
|             { | ||||
|                 return name; | ||||
|             } | ||||
|             name = (mappingInfo == null ? name : mappingInfo.DbTableName); | ||||
|             if (name.Contains(".")&& !name.Contains("(")&&!name.Contains("\".\"")) | ||||
|             { | ||||
|                 return string.Join(".", name.ToLower(isAutoToLower).Split('.').Select(it => SqlTranslationLeft + it + SqlTranslationRight)); | ||||
|             } | ||||
|             else if (name.Contains("(")) | ||||
|             { | ||||
|                 return name; | ||||
|             } | ||||
|             else if (name.Contains(SqlTranslationLeft) && name.Contains(SqlTranslationRight)) | ||||
|             { | ||||
|                 return name; | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 return SqlTranslationLeft + name.ToLower(isAutoToLower).TrimEnd('"').TrimStart('"') + SqlTranslationRight; | ||||
|             } | ||||
|         } | ||||
|         public override string GetUnionFomatSql(string sql) | ||||
|         { | ||||
|             return " ( " + sql + " )  "; | ||||
|         } | ||||
|  | ||||
|         public override Type GetNullType(string tableName, string columnName)  | ||||
|         { | ||||
|             if (tableName != null) | ||||
|                 tableName = tableName.Trim(); | ||||
|             var columnInfo=this.Context.DbMaintenance.GetColumnInfosByTableName(tableName).FirstOrDefault(z => z.DbColumnName.EqualCase(columnName)); | ||||
|             if (columnInfo != null)  | ||||
|             { | ||||
|                 var cTypeName=this.Context.Ado.DbBind.GetCsharpTypeNameByDbTypeName(columnInfo.DataType); | ||||
|                 var value=UtilMethods.GetTypeByTypeName(cTypeName); | ||||
|                 if (value != null)  | ||||
|                 { | ||||
|                     var key = "GetNullType_" + tableName + columnName; | ||||
|                     return new ReflectionInoCacheService().GetOrCreate(key, () => value); | ||||
|                 } | ||||
|             } | ||||
|             return null; | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,7 @@ | ||||
| namespace SqlSugar.TDSQLForPGODBC | ||||
| { | ||||
|     public class TDSQLForPGODBCDeleteBuilder : DeleteBuilder | ||||
|     { | ||||
|  | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,497 @@ | ||||
| using System; | ||||
| using System.Linq; | ||||
| namespace SqlSugar.TDSQLForPGODBC | ||||
| { | ||||
|     public class TDSQLForPGODBCExpressionContext : ExpressionContext, ILambdaExpressions | ||||
|     { | ||||
|         public SqlSugarProvider Context { get; set; } | ||||
|         public TDSQLForPGODBCExpressionContext() | ||||
|         { | ||||
|             base.DbMehtods = new TDSQLForPGODBCMethod(); | ||||
|         } | ||||
|         public override string SqlTranslationLeft | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return "\""; | ||||
|             } | ||||
|         } | ||||
|         public override string SqlTranslationRight | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return "\""; | ||||
|             } | ||||
|         } | ||||
|         public override string GetTranslationText(string name) | ||||
|         { | ||||
|             return SqlTranslationLeft + name.ToLower(isAutoToLower) + SqlTranslationRight; | ||||
|         } | ||||
|         public bool isAutoToLower | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return base.PgSqlIsAutoToLower; | ||||
|             } | ||||
|         } | ||||
|         public override string GetTranslationTableName(string entityName, bool isMapping = true) | ||||
|         { | ||||
|             Check.ArgumentNullException(entityName, string.Format(ErrorMessage.ObjNotExist, "Table Name")); | ||||
|             if (IsTranslationText(entityName)) return entityName; | ||||
|             isMapping = isMapping && this.MappingTables.HasValue(); | ||||
|             var isComplex = entityName.Contains(UtilConstants.Dot); | ||||
|             if (isMapping && isComplex) | ||||
|             { | ||||
|                 var columnInfo = entityName.Split(UtilConstants.DotChar); | ||||
|                 var mappingInfo = this.MappingTables.FirstOrDefault(it => it.EntityName.Equals(columnInfo.Last(), StringComparison.CurrentCultureIgnoreCase)); | ||||
|                 if (mappingInfo != null) | ||||
|                 { | ||||
|                     columnInfo[columnInfo.Length - 1] = mappingInfo.EntityName; | ||||
|                 } | ||||
|                 return string.Join(UtilConstants.Dot, columnInfo.Select(it => GetTranslationText(it))); | ||||
|             } | ||||
|             else if (isMapping) | ||||
|             { | ||||
|                 var mappingInfo = this.MappingTables.FirstOrDefault(it => it.EntityName.Equals(entityName, StringComparison.CurrentCultureIgnoreCase)); | ||||
|  | ||||
|                 var tableName = mappingInfo?.DbTableName+""; | ||||
|                 if (tableName.Contains(".")) | ||||
|                 { | ||||
|                     tableName = string.Join(UtilConstants.Dot, tableName.Split(UtilConstants.DotChar).Select(it => GetTranslationText(it))); | ||||
|                     return tableName; | ||||
|                 } | ||||
|  | ||||
|                 return SqlTranslationLeft + (mappingInfo == null ? entityName : mappingInfo.DbTableName).ToLower(isAutoToLower) + SqlTranslationRight; | ||||
|             } | ||||
|             else if (isComplex) | ||||
|             { | ||||
|                 return string.Join(UtilConstants.Dot, entityName.Split(UtilConstants.DotChar).Select(it => GetTranslationText(it))); | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 return GetTranslationText(entityName); | ||||
|             } | ||||
|         } | ||||
|         public override string GetTranslationColumnName(string columnName) | ||||
|         { | ||||
|             Check.ArgumentNullException(columnName, string.Format(ErrorMessage.ObjNotExist, "Column Name")); | ||||
|             if (columnName.Substring(0, 1) == this.SqlParameterKeyWord) | ||||
|             { | ||||
|                 return columnName; | ||||
|             } | ||||
|             if (IsTranslationText(columnName)) return columnName; | ||||
|             if (columnName.Contains(UtilConstants.Dot)) | ||||
|             { | ||||
|                 return string.Join(UtilConstants.Dot, columnName.Split(UtilConstants.DotChar).Select(it => GetTranslationText(it))); | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 return GetTranslationText(columnName); | ||||
|             } | ||||
|         } | ||||
|         public override string GetDbColumnName(string entityName, string propertyName) | ||||
|         { | ||||
|             if (this.MappingColumns.HasValue()) | ||||
|             { | ||||
|                 var mappingInfo = this.MappingColumns.SingleOrDefault(it => it.EntityName == entityName && it.PropertyName == propertyName); | ||||
|                 return (mappingInfo == null ? propertyName : mappingInfo.DbColumnName).ToLower(isAutoToLower); | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 return propertyName.ToLower(isAutoToLower); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         public  string GetValue(object entityValue) | ||||
|         { | ||||
|             if (entityValue == null) | ||||
|                 return null; | ||||
|             var type = UtilMethods.GetUnderType(entityValue.GetType()); | ||||
|             if (UtilConstants.NumericalTypes.Contains(type)) | ||||
|             { | ||||
|                 return entityValue.ToString(); | ||||
|             } | ||||
|             else if (type == UtilConstants.DateType) | ||||
|             { | ||||
|                 return this.DbMehtods.ToDate(new MethodCallExpressionModel() | ||||
|                 { | ||||
|                     Args = new System.Collections.Generic.List<MethodCallExpressionArgs>() { | ||||
|                  new MethodCallExpressionArgs(){ MemberName=$"'{entityValue}'" } | ||||
|                 } | ||||
|                 }); | ||||
|             } | ||||
|             else  | ||||
|             { | ||||
|                 return this.DbMehtods.ToString(new MethodCallExpressionModel() | ||||
|                 { | ||||
|                     Args = new System.Collections.Generic.List<MethodCallExpressionArgs>() { | ||||
|                  new MethodCallExpressionArgs(){ MemberName=$"'{entityValue}'" } | ||||
|                 } | ||||
|                 }); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|     public class TDSQLForPGODBCMethod : DefaultDbMethod, IDbMethods | ||||
|     { | ||||
|         public override string CharIndex(MethodCallExpressionModel model) | ||||
|         { | ||||
|             return string.Format(" (strpos ({1},{0})-1)", model.Args[0].MemberName, model.Args[1].MemberName); | ||||
|         } | ||||
|         public override string CharIndexNew(MethodCallExpressionModel model) | ||||
|         { | ||||
|             return string.Format(" (strpos ({0},{1}))", model.Args[0].MemberName, model.Args[1].MemberName); | ||||
|         } | ||||
|         public override string TrueValue() | ||||
|         { | ||||
|             return "true"; | ||||
|         } | ||||
|         public override string FalseValue() | ||||
|         { | ||||
|             return "false"; | ||||
|         } | ||||
|         public override string DateDiff(MethodCallExpressionModel model) | ||||
|         { | ||||
|             var parameter = (DateType)(Enum.Parse(typeof(DateType), model.Args[0].MemberValue.ObjToString())); | ||||
|             var begin = model.Args[1].MemberName; | ||||
|             var end = model.Args[2].MemberName; | ||||
|             switch (parameter) | ||||
|             { | ||||
|                 case DateType.Year: | ||||
|                     return $" ( DATE_PART('Year',  {end}   ) - DATE_PART('Year',  {begin}) )"; | ||||
|                 case DateType.Month: | ||||
|                     return $" (  ( DATE_PART('Year',  {end}   ) - DATE_PART('Year',  {begin}) ) * 12 + (DATE_PART('month', {end}) - DATE_PART('month', {begin})) )"; | ||||
|                 case DateType.Day: | ||||
|                     return $" ( DATE_PART('day', {end} - {begin}) )"; | ||||
|                 case DateType.Hour: | ||||
|                     return $" ( ( DATE_PART('day', {end} - {begin}) ) * 24 + DATE_PART('hour', {end} - {begin} ) )"; | ||||
|                 case DateType.Minute: | ||||
|                     return $" ( ( ( DATE_PART('day', {end} - {begin}) ) * 24 + DATE_PART('hour', {end} - {begin} ) ) * 60 + DATE_PART('minute', {end} - {begin} ) )"; | ||||
|                 case DateType.Second: | ||||
|                     return $" ( ( ( DATE_PART('day', {end} - {begin}) ) * 24 + DATE_PART('hour', {end} - {begin} ) ) * 60 + DATE_PART('minute', {end} - {begin} ) ) * 60 + DATE_PART('second', {end} - {begin} )"; | ||||
|                 case DateType.Millisecond: | ||||
|                     break; | ||||
|                 default: | ||||
|                     break; | ||||
|             } | ||||
|             throw new Exception(parameter + " datediff no support"); | ||||
|         } | ||||
|         public override string IIF(MethodCallExpressionModel model) | ||||
|         { | ||||
|             var parameter = model.Args[0]; | ||||
|             var parameter2 = model.Args[1]; | ||||
|             var parameter3 = model.Args[2]; | ||||
|             if (parameter.Type == UtilConstants.BoolType)  | ||||
|             { | ||||
|                 parameter.MemberName = parameter.MemberName.ToString().Replace("=1", "=true"); | ||||
|                 parameter2.MemberName = false; | ||||
|                 parameter3.MemberName = true; | ||||
|             } | ||||
|             return string.Format("( CASE  WHEN {0} THEN {1}  ELSE {2} END )", parameter.MemberName, parameter2.MemberName, parameter3.MemberName); | ||||
|         } | ||||
|         public override string DateValue(MethodCallExpressionModel model) | ||||
|         { | ||||
|             var parameter = model.Args[0]; | ||||
|             var parameter2 = model.Args[1]; | ||||
|             var format = "dd"; | ||||
|             if (parameter2.MemberValue.ObjToString() == DateType.Year.ToString()) | ||||
|             { | ||||
|                 format = "yyyy"; | ||||
|             } | ||||
|             if (parameter2.MemberValue.ObjToString() == DateType.Month.ToString()) | ||||
|             { | ||||
|                 format = "MM"; | ||||
|             } | ||||
|             if (parameter2.MemberValue.ObjToString() == DateType.Day.ToString()) | ||||
|             { | ||||
|                 format = "dd"; | ||||
|             } | ||||
|             if (parameter2.MemberValue.ObjToString() == DateType.Hour.ToString()) | ||||
|             { | ||||
|                 format = "hh24"; | ||||
|             } | ||||
|             if (parameter2.MemberValue.ObjToString() == DateType.Minute.ToString()) | ||||
|             { | ||||
|                 format = "mi"; | ||||
|             } | ||||
|             if (parameter2.MemberValue.ObjToString() == DateType.Second.ToString()) | ||||
|             { | ||||
|                 format = "ss"; | ||||
|             } | ||||
|             if (parameter2.MemberValue.ObjToString() == DateType.Millisecond.ToString()) | ||||
|             { | ||||
|                 format = "ms"; | ||||
|             } | ||||
|             if (parameter2.MemberValue.ObjToString() == DateType.Quarter.ToString()) | ||||
|             { | ||||
|                 format = "q"; | ||||
|             } | ||||
|             if (parameter2.MemberValue.ObjToString() == DateType.Weekday.ToString()) | ||||
|             { | ||||
|                 return $"  extract(DOW FROM cast({parameter.MemberName} as TIMESTAMP)) "; | ||||
|             } | ||||
|   | ||||
|             return string.Format(" cast( to_char({1},'{0}')as integer ) ", format, parameter.MemberName); | ||||
|         } | ||||
|  | ||||
|         public override string Contains(MethodCallExpressionModel model) | ||||
|         { | ||||
|             var parameter = model.Args[0]; | ||||
|             var parameter2 = model.Args[1]; | ||||
|             return string.Format(" ({0} like concat('%',{1},'%')) ", parameter.MemberName, parameter2.MemberName  ); | ||||
|         } | ||||
|  | ||||
|         public override string StartsWith(MethodCallExpressionModel model) | ||||
|         { | ||||
|             var parameter = model.Args[0]; | ||||
|             var parameter2 = model.Args[1]; | ||||
|             return string.Format(" ({0} like concat({1},'%')) ", parameter.MemberName, parameter2.MemberName); | ||||
|         } | ||||
|  | ||||
|         public override string EndsWith(MethodCallExpressionModel model) | ||||
|         { | ||||
|             var parameter = model.Args[0]; | ||||
|             var parameter2 = model.Args[1]; | ||||
|             return string.Format(" ({0} like concat('%',{1}))", parameter.MemberName,parameter2.MemberName); | ||||
|         } | ||||
|  | ||||
|         public override string DateIsSameDay(MethodCallExpressionModel model) | ||||
|         { | ||||
|             var parameter = model.Args[0]; | ||||
|             var parameter2 = model.Args[1]; | ||||
|             return string.Format(" ( to_char({0},'yyyy-MM-dd')=to_char({1},'yyyy-MM-dd') ) ", parameter.MemberName, parameter2.MemberName); ; | ||||
|         } | ||||
|  | ||||
|         public override string HasValue(MethodCallExpressionModel model) | ||||
|         { | ||||
|             var parameter = model.Args[0]; | ||||
|             return string.Format("( {0} IS NOT NULL )", parameter.MemberName); | ||||
|         } | ||||
|  | ||||
|         public override string DateIsSameByType(MethodCallExpressionModel model) | ||||
|         { | ||||
|             var parameter = model.Args[0]; | ||||
|             var parameter2 = model.Args[1]; | ||||
|             var parameter3 = model.Args[2]; | ||||
|             DateType dateType =(DateType)parameter3.MemberValue; | ||||
|             var format = "yyyy-MM-dd"; | ||||
|             if (dateType == DateType.Quarter) | ||||
|             { | ||||
|                 return string.Format(" (date_trunc('quarter',{0})=date_trunc('quarter',{1}) ) ", parameter.MemberName, parameter2.MemberName,format); | ||||
|             } | ||||
|             switch (dateType) | ||||
|             { | ||||
|                 case DateType.Year: | ||||
|                     format = "yyyy"; | ||||
|                     break; | ||||
|                 case DateType.Month: | ||||
|                     format = "yyyy-MM"; | ||||
|                     break; | ||||
|                 case DateType.Day: | ||||
|                     break; | ||||
|                 case DateType.Hour: | ||||
|                     format = "yyyy-MM-dd HH"; | ||||
|                     break; | ||||
|                 case DateType.Second: | ||||
|                     format = "yyyy-MM-dd HH:mm:ss"; | ||||
|                     break; | ||||
|                 case DateType.Minute: | ||||
|                     format = "yyyy-MM-dd HH:mm"; | ||||
|                     break; | ||||
|                 case DateType.Millisecond: | ||||
|                     format = "yyyy-MM-dd HH:mm.ms"; | ||||
|                     break; | ||||
|                 default: | ||||
|                     break; | ||||
|             } | ||||
|             return string.Format(" ( to_char({0},'{2}')=to_char({1},'{2}') ) ", parameter.MemberName, parameter2.MemberName, format); | ||||
|         } | ||||
|  | ||||
|         public override string ToDate(MethodCallExpressionModel model) | ||||
|         { | ||||
|             var parameter = model.Args[0]; | ||||
|             return string.Format(" CAST({0} AS timestamp)", parameter.MemberName); | ||||
|         } | ||||
|         public override string DateAddByType(MethodCallExpressionModel model) | ||||
|         { | ||||
|             var parameter = model.Args[0]; | ||||
|             var parameter2 = model.Args[1]; | ||||
|             var parameter3 = model.Args[2]; | ||||
|             return string.Format(" ({1} +  ({2}||'{0}')::INTERVAL) ", parameter3.MemberValue, parameter.MemberName, parameter2.MemberName); | ||||
|         } | ||||
|  | ||||
|         public override string DateAddDay(MethodCallExpressionModel model) | ||||
|         { | ||||
|             var parameter = model.Args[0]; | ||||
|             var parameter2 = model.Args[1]; | ||||
|             return string.Format(" ({0} + ({1}||'day')::INTERVAL) ", parameter.MemberName, parameter2.MemberName); | ||||
|         } | ||||
|  | ||||
|         public override string ToInt32(MethodCallExpressionModel model) | ||||
|         { | ||||
|             var parameter = model.Args[0]; | ||||
|             return string.Format(" CAST({0} AS INT4)", parameter.MemberName); | ||||
|         } | ||||
|  | ||||
|         public override string ToInt64(MethodCallExpressionModel model) | ||||
|         { | ||||
|             var parameter = model.Args[0]; | ||||
|             return string.Format(" CAST({0} AS INT8)", parameter.MemberName); | ||||
|         } | ||||
|  | ||||
|         public override string ToString(MethodCallExpressionModel model) | ||||
|         { | ||||
|             var parameter = model.Args[0]; | ||||
|             return string.Format(" CAST({0} AS VARCHAR)", parameter.MemberName); | ||||
|         } | ||||
|  | ||||
|         public override string ToGuid(MethodCallExpressionModel model) | ||||
|         { | ||||
|             var parameter = model.Args[0]; | ||||
|             return string.Format(" CAST({0} AS UUID)", parameter.MemberName); | ||||
|         } | ||||
|  | ||||
|         public override string ToDouble(MethodCallExpressionModel model) | ||||
|         { | ||||
|             var parameter = model.Args[0]; | ||||
|             return string.Format(" CAST({0} AS DECIMAL(18,4))", parameter.MemberName); | ||||
|         } | ||||
|  | ||||
|         public override string ToBool(MethodCallExpressionModel model) | ||||
|         { | ||||
|             var parameter = model.Args[0]; | ||||
|             return string.Format(" CAST({0} AS boolean)", parameter.MemberName); | ||||
|         } | ||||
|  | ||||
|         public override string ToDecimal(MethodCallExpressionModel model) | ||||
|         { | ||||
|             var parameter = model.Args[0]; | ||||
|             return string.Format(" CAST({0} AS DECIMAL(18,4))", parameter.MemberName); | ||||
|         } | ||||
|  | ||||
|         public override string Length(MethodCallExpressionModel model) | ||||
|         { | ||||
|             var parameter = model.Args[0]; | ||||
|             return string.Format(" LENGTH({0})", parameter.MemberName); | ||||
|         } | ||||
|         public override string IsNullOrEmpty(MethodCallExpressionModel model) | ||||
|         { | ||||
|             if (  | ||||
|                 model.Conext?.SugarContext?.Context?.CurrentConnectionConfig?.MoreSettings?.DatabaseModel == DbType.Vastbase|| | ||||
|                 model.Conext?.SugarContext?.Context?.CurrentConnectionConfig?.MoreSettings?.DatabaseModel == DbType.GaussDB) | ||||
|             { | ||||
|                 var parameter = model.Args[0]; | ||||
|                 return string.Format("( {0} IS NULL )", parameter.MemberName); | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 return base.IsNullOrEmpty(model); | ||||
|             } | ||||
|         } | ||||
|         public override string MergeString(params string[] strings) | ||||
|         { | ||||
|             var key = Guid.NewGuid() + ""; | ||||
|             return " concat("+string.Join(",", strings.Select(it=>it?.Replace("+", key))).Replace("+", "").Replace(key, "+") + ") "; | ||||
|         } | ||||
|         public override string IsNull(MethodCallExpressionModel model) | ||||
|         { | ||||
|             var parameter = model.Args[0]; | ||||
|             var parameter1 = model.Args[1]; | ||||
|             return string.Format("(CASE WHEN  {0} IS NULL THEN  {1} ELSE {0} END)", parameter.MemberName, parameter1.MemberName); | ||||
|         } | ||||
|         public override string GetDate() | ||||
|         { | ||||
|             return "NOW()"; | ||||
|         } | ||||
|         public override string GetRandom() | ||||
|         { | ||||
|             return "RANDOM()"; | ||||
|         } | ||||
|  | ||||
|         public override string EqualTrue(string fieldName) | ||||
|         { | ||||
|             return "( " + fieldName + "=true )"; | ||||
|         } | ||||
|  | ||||
|         public override string JsonField(MethodCallExpressionModel model) | ||||
|         { | ||||
|             var parameter = model.Args[0]; | ||||
|             var parameter1 = model.Args[1]; | ||||
|             //var parameter2 = model.Args[2]; | ||||
|             //var parameter3= model.Args[3]; | ||||
|             var result= GetJson(parameter.MemberName, parameter1.MemberName, model.Args.Count()==2); | ||||
|             if (model.Args.Count > 2)  | ||||
|             { | ||||
|                result = GetJson(result, model.Args[2].MemberName, model.Args.Count() == 3); | ||||
|             } | ||||
|             if (model.Args.Count > 3) | ||||
|             { | ||||
|                 result = GetJson(result, model.Args[3].MemberName, model.Args.Count() == 4); | ||||
|             } | ||||
|             if (model.Args.Count > 4) | ||||
|             { | ||||
|                 result = GetJson(result, model.Args[4].MemberName, model.Args.Count() == 5); | ||||
|             } | ||||
|             if (model.Args.Count > 5) | ||||
|             { | ||||
|                 result = GetJson(result, model.Args[5].MemberName, model.Args.Count() == 6); | ||||
|             } | ||||
|             return result; | ||||
|         } | ||||
|  | ||||
|         public override string JsonContainsFieldName(MethodCallExpressionModel model) | ||||
|         { | ||||
|             var parameter = model.Args[0]; | ||||
|             var parameter1 = model.Args[1]; | ||||
|             return $"({parameter.MemberName}::jsonb ?{parameter1.MemberName})"; | ||||
|         } | ||||
|  | ||||
|         private string GetJson(object memberName1, object memberName2,bool isLast) | ||||
|         { | ||||
|             if (isLast) | ||||
|             { | ||||
|                 return $"({memberName1}::json->>{memberName2})"; | ||||
|             } | ||||
|             else  | ||||
|             { | ||||
|                 return $"({memberName1}->{memberName2})"; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         public override string JsonArrayLength(MethodCallExpressionModel model) | ||||
|         { | ||||
|             var parameter = model.Args[0]; | ||||
|             //var parameter1 = model.Args[1]; | ||||
|             return $" json_array_length({parameter.MemberName}::json) "; | ||||
|         } | ||||
|  | ||||
|         public override string JsonParse(MethodCallExpressionModel model) | ||||
|         { | ||||
|             var parameter = model.Args[0]; | ||||
|             //var parameter1 = model.Args[1]; | ||||
|             return $" ({parameter.MemberName}::json) "; | ||||
|         } | ||||
|  | ||||
|         public override string JsonArrayAny(MethodCallExpressionModel model) | ||||
|         { | ||||
|             if (UtilMethods.IsNumber(model.Args[1].MemberValue.GetType().Name)) | ||||
|             { | ||||
|                 return $" {model.Args[0].MemberName}::jsonb @> '[{model.Args[1].MemberValue.ObjToStringNoTrim().ToSqlFilter()}]'::jsonb "; | ||||
|             } | ||||
|             else  | ||||
|             { | ||||
|                 return $" {model.Args[0].MemberName}::jsonb @> '[\"{model.Args[1].MemberValue}\"]'::jsonb "; | ||||
|             } | ||||
|         } | ||||
|         public override string JsonListObjectAny(MethodCallExpressionModel model) | ||||
|         { | ||||
|             if (UtilMethods.IsNumber(model.Args[2].MemberValue.GetType().Name)) | ||||
|             { | ||||
|                 return $" {model.Args[0].MemberName}::jsonb @> '[{{\"{model.Args[1].MemberValue}\":{model.Args[2].MemberValue}}}]'::jsonb "; | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 return $" {model.Args[0].MemberName}::jsonb @> '[{{\"{model.Args[1].MemberValue}\":\"{model.Args[2].MemberValue.ObjToStringNoTrim().ToSqlFilter()}\"}}]'::jsonb "; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,169 @@ | ||||
| using Npgsql; | ||||
| using NpgsqlTypes; | ||||
| using System; | ||||
| using System.Collections.Generic; | ||||
| using System.Data; | ||||
| using System.Linq; | ||||
| using System.Text; | ||||
| using System.Threading.Tasks; | ||||
|  | ||||
| namespace SqlSugar.TDSQLForPGODBC | ||||
| { | ||||
|     public class TDSQLForPGODBCFastBuilder : FastBuilder, IFastBuilder | ||||
|     { | ||||
|         public static Dictionary<string , NpgsqlDbType> PgSqlType = UtilMethods.EnumToDictionary<NpgsqlDbType>(); | ||||
|         private EntityInfo entityInfo; | ||||
|  | ||||
|         public TDSQLForPGODBCFastBuilder(EntityInfo entityInfo) | ||||
|         { | ||||
|             this.entityInfo = entityInfo; | ||||
|         } | ||||
|  | ||||
|         public override string UpdateSql { get; set; } = @"UPDATE  {1}    SET {0}  FROM   {2}  AS TE  WHERE {3} | ||||
| "; | ||||
|  | ||||
|         //public virtual async Task<int> UpdateByTempAsync(string tableName, string tempName, string[] updateColumns, string[] whereColumns) | ||||
|         //{ | ||||
|         //    Check.ArgumentNullException(!updateColumns.Any(), "update columns count is 0"); | ||||
|         //    Check.ArgumentNullException(!whereColumns.Any(), "where columns count is 0"); | ||||
|         //    var sets = string.Join(",", updateColumns.Select(it => $"TM.{it}=TE.{it}")); | ||||
|         //    var wheres = string.Join(",", whereColumns.Select(it => $"TM.{it}=TE.{it}")); | ||||
|         //    string sql = string.Format(UpdateSql, sets, tableName, tempName, wheres); | ||||
|         //    return await this.Context.Ado.ExecuteCommandAsync(sql); | ||||
|         //} | ||||
|         public async Task<int> ExecuteBulkCopyAsync(DataTable dt) | ||||
|         { | ||||
|             List<string> lsColNames = new List<string>(); | ||||
|             for (int i = 0; i < dt.Columns.Count; i++) | ||||
|             { | ||||
|                 lsColNames.Add($"\"{dt.Columns[i].ColumnName}\""); | ||||
|             } | ||||
|             string copyString = $"COPY  {dt.TableName} ( {string.Join(",", lsColNames) } ) FROM STDIN (FORMAT BINARY)"; | ||||
|             if (this.Context?.CurrentConnectionConfig?.MoreSettings?.DatabaseModel == DbType.OpenGauss) | ||||
|             { | ||||
|                 copyString = copyString.Replace("(FORMAT BINARY)", "(FORMAT 'BINARY')"); | ||||
|             } | ||||
|             NpgsqlConnection conn = (NpgsqlConnection)this.Context.Ado.Connection; | ||||
|             var columns = this.Context.DbMaintenance.GetColumnInfosByTableName(this.entityInfo.DbTableName); | ||||
|             try | ||||
|             { | ||||
|                 var identityColumnInfo = this.entityInfo.Columns.FirstOrDefault(it => it.IsIdentity); | ||||
|                 if (identityColumnInfo != null) | ||||
|                 { | ||||
|                     throw new Exception("PgSql bulkcopy no support identity"); | ||||
|                 } | ||||
|                 BulkCopy(dt, copyString, conn, columns); | ||||
|             } | ||||
|             catch (Exception ex) | ||||
|             { | ||||
|                 throw ex; | ||||
|             } | ||||
|             finally  | ||||
|             { | ||||
|                 base.CloseDb(); | ||||
|             } | ||||
|             return await Task.FromResult(dt.Rows.Count); | ||||
|         } | ||||
|  | ||||
|         private  void BulkCopy(DataTable dt, string copyString, NpgsqlConnection conn, List<DbColumnInfo> columns) | ||||
|         { | ||||
|             if (conn.State == ConnectionState.Closed) | ||||
|                 conn.Open(); | ||||
|             List<ColumnView> columnViews = new List<ColumnView>(); | ||||
|             foreach (DataColumn item in dt.Columns) | ||||
|             { | ||||
|                 ColumnView result = new ColumnView(); | ||||
|                 result.DbColumnInfo = columns.FirstOrDefault(it => it.DbColumnName.EqualCase(item.ColumnName)); | ||||
|                 result.DataColumn = item; | ||||
|                 result.EntityColumnInfo=this.entityInfo.Columns.FirstOrDefault(it => it.DbColumnName.EqualCase(item.ColumnName)); | ||||
|                 var key = result.DbColumnInfo?.DataType?.ToLower(); | ||||
|                 if (result.DbColumnInfo == null)  | ||||
|                 { | ||||
|                     result.Type = null; | ||||
|                 } | ||||
|                 else if (PgSqlType.ContainsKey(key)) | ||||
|                 { | ||||
|                     result.Type = PgSqlType[key]; | ||||
|                 } | ||||
|                 else if (key?.First() == '_') | ||||
|                 { | ||||
|                     if (key == "_int4") | ||||
|                     {  | ||||
|                         result.Type = NpgsqlDbType.Array | NpgsqlDbType.Integer; | ||||
|                     } | ||||
|                     else if (key == "_int2") | ||||
|                     { | ||||
|                         result.Type = NpgsqlDbType.Array | NpgsqlDbType.Smallint; | ||||
|                     } | ||||
|                     else if (key == "_int8") | ||||
|                     { | ||||
|                         result.Type = NpgsqlDbType.Array | NpgsqlDbType.Bigint; | ||||
|                     } | ||||
|                     else | ||||
|                     { | ||||
|                         var type = PgSqlType[key.Substring(1)]; | ||||
|                         result.Type = NpgsqlDbType.Array | type; | ||||
|                     } | ||||
|                 } | ||||
|                 else | ||||
|                 { | ||||
|                     result.Type = null; | ||||
|                 } | ||||
|                 columnViews.Add(result); | ||||
|             } | ||||
|             using (var writer = conn.BeginBinaryImport(copyString)) | ||||
|             { | ||||
|                 foreach (DataRow row in dt.Rows) | ||||
|                 { | ||||
|                     writer.StartRow(); | ||||
|                     foreach (var column in columnViews) | ||||
|                     { | ||||
|                         var value = row[column.DataColumn.ColumnName]; | ||||
|                         if (value == null) | ||||
|                         { | ||||
|                             value = DBNull.Value; | ||||
|                         } | ||||
|                         //else if (value is double&&this.Context?.CurrentConnectionConfig?.MoreSettings?.DatabaseModel==null)  | ||||
|                         //{ | ||||
|                         //    column.Type = NpgsqlDbType.Double; | ||||
|                         //} | ||||
|                         if (column.Type == null) | ||||
|                         { | ||||
|                             writer.Write(value); | ||||
|                         } | ||||
|                         else   | ||||
|                         { | ||||
|                             writer.Write(value, column.Type.Value); | ||||
|                         }                     | ||||
|                     } | ||||
|                 } | ||||
|                 writer.Complete(); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|      | ||||
|         public override async Task<int> UpdateByTempAsync(string tableName, string tempName, string[] updateColumns, string[] whereColumns) | ||||
|         { | ||||
|             var sqlquerybulder= this.Context.Queryable<object>().SqlBuilder; | ||||
|             Check.ArgumentNullException(!updateColumns.Any(), "update columns count is 0"); | ||||
|             Check.ArgumentNullException(!whereColumns.Any(), "where columns count is 0"); | ||||
|             var sets = string.Join(",", updateColumns.Select(it => $"{sqlquerybulder.GetTranslationColumnName(it)}=TE.{sqlquerybulder.GetTranslationColumnName(it)}")); | ||||
|             var wheres = string.Join(" AND ", whereColumns.Select(it => $"{tableName}.{sqlquerybulder.GetTranslationColumnName(it)}=TE.{sqlquerybulder.GetTranslationColumnName(it)}")); | ||||
|             string sql = string.Format(UpdateSql, sets, tableName, tempName, wheres); | ||||
|             return await this.Context.Ado.ExecuteCommandAsync(sql); | ||||
|         } | ||||
|         public override async Task CreateTempAsync<T>(DataTable dt)  | ||||
|         { | ||||
|             await this.Context.Queryable<T>().Where(it => false).AS(dt.TableName).Select("  * into  temp mytemptable").ToListAsync(); | ||||
|             dt.TableName = "mytemptable"; | ||||
|         } | ||||
|  | ||||
|         public class ColumnView | ||||
|         { | ||||
|             public DataColumn DataColumn { get; set; } | ||||
|             public EntityColumnInfo EntityColumnInfo { get; set; } | ||||
|             public DbColumnInfo DbColumnInfo { get; set; } | ||||
|             public NpgsqlDbType? Type { get; set; } | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,196 @@ | ||||
| using System; | ||||
| using System.Linq; | ||||
| using System.Text; | ||||
|  | ||||
| namespace SqlSugar.TDSQLForPGODBC | ||||
| { | ||||
|     public class TDSQLForPGODBCInsertBuilder : InsertBuilder | ||||
|     { | ||||
|         public override string SqlTemplate | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 if (IsReturnIdentity) | ||||
|                 { | ||||
|                     return @"INSERT INTO {0}  | ||||
|            ({1}) | ||||
|      VALUES | ||||
|            ({2}) returning $PrimaryKey"; | ||||
|                 } | ||||
|                 else | ||||
|                 { | ||||
|                     return @"INSERT INTO {0}  | ||||
|            ({1}) | ||||
|      VALUES | ||||
|            ({2}) ;"; | ||||
|  | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         public override string SqlTemplateBatch => "INSERT INTO {0} ({1})"; | ||||
|         public override string SqlTemplateBatchUnion => " VALUES "; | ||||
|  | ||||
|         public override string SqlTemplateBatchSelect => " {0} "; | ||||
|  | ||||
|         public override Func<string, string, string> ConvertInsertReturnIdFunc { get; set; } = (name, sql) => | ||||
|         { | ||||
|             return sql.Trim().TrimEnd(';')+ $"returning {name} "; | ||||
|         }; | ||||
|         public override string ToSqlString() | ||||
|         { | ||||
|             if (IsNoInsertNull) | ||||
|             { | ||||
|                 DbColumnInfoList = DbColumnInfoList.Where(it => it.Value != null).ToList(); | ||||
|             } | ||||
|             var groupList = DbColumnInfoList.GroupBy(it => it.TableId).ToList(); | ||||
|             var isSingle = groupList.Count() == 1; | ||||
|             string columnsString = string.Join(",", groupList.First().Select(it => Builder.GetTranslationColumnName(it.DbColumnName))); | ||||
|             if (isSingle) | ||||
|             { | ||||
|                 string columnParametersString = string.Join(",", this.DbColumnInfoList.Select(it =>base.GetDbColumn(it, Builder.SqlParameterKeyWord + it.DbColumnName))); | ||||
|                 ActionMinDate(); | ||||
|                 return GetIgnoreSql(string.Format(SqlTemplate, GetTableNameString, columnsString, columnParametersString)); | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 StringBuilder batchInsetrSql = new StringBuilder(); | ||||
|                 int pageSize = 200; | ||||
|                 int pageIndex = 1; | ||||
|                 if (IsNoPage&&IsReturnPkList)  | ||||
|                 { | ||||
|                     pageSize = groupList.Count; | ||||
|                 } | ||||
|                 int totalRecord = groupList.Count; | ||||
|                 int pageCount = (totalRecord + pageSize - 1) / pageSize; | ||||
|                 while (pageCount >= pageIndex) | ||||
|                 { | ||||
|                     batchInsetrSql.AppendFormat(SqlTemplateBatch, GetTableNameString, columnsString); | ||||
|                     int i = 0; | ||||
|                     foreach (var columns in groupList.Skip((pageIndex - 1) * pageSize).Take(pageSize).ToList()) | ||||
|                     { | ||||
|                         var isFirst = i == 0; | ||||
|                         if (isFirst) | ||||
|                         { | ||||
|                             batchInsetrSql.Append(SqlTemplateBatchUnion); | ||||
|                         } | ||||
|                         batchInsetrSql.Append("\r\n ( " + string.Join(",", columns.Select(it => | ||||
|                         { | ||||
|                             if (it.InsertServerTime || it.InsertSql.HasValue()||it.SqlParameterDbType is Type|| it?.PropertyType?.Name=="DateOnly" || it?.PropertyType?.Name == "TimeOnly") | ||||
|                             { | ||||
|                                 return GetDbColumn(it, null); | ||||
|                             } | ||||
|                             object value = null; | ||||
|                             if (it.Value is DateTime) | ||||
|                             { | ||||
|                                 var date = ((DateTime)it.Value); | ||||
|                                 value = date.ToString("O"); | ||||
|                                 if (date==DateTime.MaxValue)  | ||||
|                                 { | ||||
|                                     value = "9999-12-31T23:59:59.999999"; | ||||
|                                 } | ||||
|                             } | ||||
|                             else if (it.Value  is DateTimeOffset) | ||||
|                             { | ||||
|                                 return FormatDateTimeOffset(it.Value); | ||||
|                             } | ||||
|                             else if (it.IsArray&&it.Value!=null)  | ||||
|                             { | ||||
|                                 return FormatValue(it.Value,it.PropertyName,i,it); | ||||
|                             } | ||||
|                             else if (it.Value is byte[]) | ||||
|                             { | ||||
|                                 return FormatValue(it.Value, it.PropertyName, i, it); | ||||
|                             } | ||||
|                             else | ||||
|                             { | ||||
|                                 value = it.Value; | ||||
|                             } | ||||
|                             if (value == null||value==DBNull.Value) | ||||
|                             { | ||||
|                                 return string.Format(SqlTemplateBatchSelect, "NULL"); | ||||
|                             } | ||||
|                             return string.Format(SqlTemplateBatchSelect, "'" + value.ObjToStringNoTrim().ToSqlFilter() + "'"); | ||||
|                         })) + "),"); | ||||
|                         ++i; | ||||
|                     } | ||||
|                     pageIndex++; | ||||
|                     batchInsetrSql.Remove(batchInsetrSql.Length - 1,1).Append("\r\n;\r\n"); | ||||
|                 } | ||||
|                 return GetIgnoreSql(batchInsetrSql.ToString()); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         public object FormatValue(object value, string name, int i, DbColumnInfo columnInfo) | ||||
|         { | ||||
|             if (value == null) | ||||
|             { | ||||
|                 return "NULL"; | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 var type = value.GetType(); | ||||
|                 if (type == UtilConstants.ByteArrayType||type == UtilConstants.DateType || columnInfo.IsArray || columnInfo.IsJson) | ||||
|                 { | ||||
|                     var parameterName = this.Builder.SqlParameterKeyWord + name + i; | ||||
|                     var paramter = new SugarParameter(parameterName, value); | ||||
|                     if (columnInfo.IsJson) | ||||
|                     { | ||||
|                         paramter.IsJson = true; | ||||
|                     } | ||||
|                     if (columnInfo.IsArray) | ||||
|                     { | ||||
|                         paramter.IsArray = true; | ||||
|                     } | ||||
|                     this.Parameters.Add(paramter); | ||||
|                     return parameterName; | ||||
|                 } | ||||
|                 else if (type == UtilConstants.ByteArrayType) | ||||
|                 { | ||||
|                     string bytesString = "0x" + BitConverter.ToString((byte[])value); | ||||
|                     return bytesString; | ||||
|                 } | ||||
|                 else if (type.IsEnum()) | ||||
|                 { | ||||
|                     if (this.Context.CurrentConnectionConfig.MoreSettings?.TableEnumIsString == true) | ||||
|                     { | ||||
|                         return value.ToSqlValue(); | ||||
|                     } | ||||
|                     else | ||||
|                     { | ||||
|                         return Convert.ToInt64(value); | ||||
|                     } | ||||
|                 } | ||||
|                 else if (type == UtilConstants.DateTimeOffsetType) | ||||
|                 { | ||||
|                     return FormatDateTimeOffset(value); | ||||
|                 } | ||||
|                 else if (type == UtilConstants.BoolType) | ||||
|                 { | ||||
|                     return value.ObjToBool() ? "1" : "0"; | ||||
|                 } | ||||
|                 else if (type == UtilConstants.StringType || type == UtilConstants.ObjType) | ||||
|                 { | ||||
|                     return "'" + value.ToString().ToSqlFilter() + "'"; | ||||
|                 } | ||||
|                 else | ||||
|                 { | ||||
|                     return "'" + value.ToString() + "'"; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         public override string FormatDateTimeOffset(object value) | ||||
|         { | ||||
|             return "'" + ((DateTimeOffset)value).ToString("o") + "'"; | ||||
|         } | ||||
|           | ||||
|         private string GetIgnoreSql(string sql) | ||||
|         { | ||||
|             if (this.ConflictNothing?.Any() == true) | ||||
|             { | ||||
|                 sql = sql.Replace(";", $"  ON CONFLICT ({string.Join(",", this.ConflictNothing)}) DO NOTHING;"); | ||||
|             } | ||||
|  | ||||
|             return sql; | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,130 @@ | ||||
| using System.Linq; | ||||
| using System.Text; | ||||
| using System.Text.RegularExpressions; | ||||
|  | ||||
| namespace SqlSugar.TDSQLForPGODBC | ||||
| { | ||||
|     public partial class TDSQLForPGODBCQueryBuilder : QueryBuilder | ||||
|     { | ||||
|         #region Sql Template | ||||
|         public override string PageTempalte | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 /* | ||||
|                  SELECT * FROM TABLE WHERE CONDITION ORDER BY ID DESC LIMIT 10 offset 0 | ||||
|                  */ | ||||
|                 var template = "SELECT {0} FROM {1} {2} {3} {4} LIMIT {6} offset {5}"; | ||||
|                 return template; | ||||
|             } | ||||
|         } | ||||
|         public override string DefaultOrderByTemplate | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return "ORDER BY NOW() "; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         #endregion | ||||
|  | ||||
|         #region Common Methods | ||||
|         public override string GetTableNameString | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 if (this.TableShortName != null&&this.Context.CurrentConnectionConfig?.MoreSettings?.PgSqlIsAutoToLower==false)  | ||||
|                 { | ||||
|                     this.TableShortName = Builder.GetTranslationColumnName(this.TableShortName); | ||||
|                 } | ||||
|                 return base.GetTableNameString; | ||||
|             } | ||||
|         } | ||||
|         public override bool IsComplexModel(string sql) | ||||
|         { | ||||
|             return Regex.IsMatch(sql, @"AS ""\w+\.\w+""")|| Regex.IsMatch(sql, @"AS ""\w+\.\w+\.\w+"""); | ||||
|         } | ||||
|         public override string ToSqlString() | ||||
|         { | ||||
|             base.AppendFilter(); | ||||
|             string oldOrderValue = this.OrderByValue; | ||||
|             var isNullOrderValue = Skip == 0 && Take == 1 && oldOrderValue == "ORDER BY NOW() "; | ||||
|             if (isNullOrderValue)  | ||||
|             { | ||||
|                 this.OrderByValue = null; | ||||
|             } | ||||
|             string result = null; | ||||
|             sql = new StringBuilder(); | ||||
|             sql.AppendFormat(SqlTemplate, GetSelectValue, GetTableNameString, GetWhereValueString, GetGroupByString + HavingInfos, (Skip != null || Take != null) ? null : GetOrderByString); | ||||
|             if (IsCount) { return sql.ToString(); } | ||||
|             if (Skip != null && Take == null) | ||||
|             { | ||||
|                 if (this.OrderByValue == "ORDER BY ") this.OrderByValue += GetSelectValue.Split(',')[0]; | ||||
|                 result = string.Format(PageTempalte, GetSelectValue, GetTableNameString, GetWhereValueString, GetGroupByString + HavingInfos, (Skip != null || Take != null) ? null : GetOrderByString, Skip.ObjToInt(), long.MaxValue); | ||||
|             } | ||||
|             else if (Skip == null && Take != null) | ||||
|             { | ||||
|                 if (this.OrderByValue == "ORDER BY ") this.OrderByValue += GetSelectValue.Split(',')[0]; | ||||
|                 result = string.Format(PageTempalte, GetSelectValue, GetTableNameString, GetWhereValueString, GetGroupByString + HavingInfos, GetOrderByString, 0, Take.ObjToInt()); | ||||
|             } | ||||
|             else if (Skip != null && Take != null) | ||||
|             { | ||||
|                 if (this.OrderByValue == "ORDER BY ") this.OrderByValue += GetSelectValue.Split(',')[0]; | ||||
|                 result = string.Format(PageTempalte, GetSelectValue, GetTableNameString, GetWhereValueString, GetGroupByString + HavingInfos, GetOrderByString, Skip.ObjToInt() > 0 ? Skip.ObjToInt() : 0, Take); | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 result = sql.ToString(); | ||||
|             } | ||||
|             this.OrderByValue = oldOrderValue; | ||||
|             result = GetSqlQuerySql(result); | ||||
|             if (result.IndexOf("-- No table") > 0) | ||||
|             { | ||||
|                 return "-- No table"; | ||||
|             } | ||||
|             if (TranLock != null) | ||||
|             { | ||||
|                 result = result + TranLock; | ||||
|             } | ||||
|             //if (result.Contains("uuid_generate_v4()"))  | ||||
|             //{ | ||||
|             //    result=" CREATE EXTENSION IF NOT EXISTS pgcrypto;CREATE EXTENSION IF NOT EXISTS \"uuid-ossp\"; "+ result; | ||||
|             //} | ||||
|             return result; | ||||
|         } | ||||
|  | ||||
|         #endregion | ||||
|  | ||||
|         #region Get SQL Partial | ||||
|         public override string GetSelectValue | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 string result = string.Empty; | ||||
|                 if (this.SelectValue == null || this.SelectValue is string) | ||||
|                 { | ||||
|                     result = GetSelectValueByString(); | ||||
|                 } | ||||
|                 else | ||||
|                 { | ||||
|                     result = GetSelectValueByExpression(); | ||||
|                 } | ||||
|                 if (this.SelectType == ResolveExpressType.SelectMultiple) | ||||
|                 { | ||||
|                     this.SelectCacheKey = this.SelectCacheKey + string.Join("-", this.JoinQueryInfos.Select(it => it.TableName)); | ||||
|                 } | ||||
|                 if (IsDistinct&&result?.TrimStart()?.StartsWith("distinct ")!=true)  | ||||
|                 { | ||||
|                     result = "distinct "+result; | ||||
|                 } | ||||
|                 if (this.SubToListParameters != null && this.SubToListParameters.Any()) | ||||
|                 { | ||||
|                     result = SubToListMethod(result); | ||||
|                 } | ||||
|                 return result; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         #endregion | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,280 @@ | ||||
| using System; | ||||
| using System.Collections.Generic; | ||||
| using System.Linq; | ||||
| using System.Text; | ||||
|  | ||||
| namespace SqlSugar.TDSQLForPGODBC | ||||
| { | ||||
|     public class TDSQLForPGODBCUpdateBuilder : UpdateBuilder | ||||
|     { | ||||
|         public override string SqlTemplateBatch | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return @"UPDATE  {1} {2} SET {0} FROM  ${{0}}  "; | ||||
|             } | ||||
|         } | ||||
|         public override string SqlTemplateJoin | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return @"            (VALUES | ||||
|               {0} | ||||
|  | ||||
|             ) AS T ({2}) WHERE {1} | ||||
|                  "; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         public override string SqlTemplateBatchUnion | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return ","; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         public  object FormatValue(object value,string name,int i,DbColumnInfo columnInfo) | ||||
|         { | ||||
|             if (value == null) | ||||
|             { | ||||
|                 return "NULL"; | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 var type =UtilMethods.GetUnderType(value.GetType()); | ||||
|                 if (type == UtilConstants.ByteArrayType||type == UtilConstants.DateType||columnInfo.IsArray||columnInfo.IsJson) | ||||
|                 { | ||||
|                     var parameterName = this.Builder.SqlParameterKeyWord + name + i; | ||||
|                     var paramter = new SugarParameter(parameterName, value); | ||||
|                     if (columnInfo.IsJson)  | ||||
|                     { | ||||
|                         paramter.IsJson = true; | ||||
|                     } | ||||
|                     if (columnInfo.IsArray)  | ||||
|                     { | ||||
|                         paramter.IsArray = true; | ||||
|                     } | ||||
|                     this.Parameters.Add(paramter); | ||||
|                     return parameterName; | ||||
|                 } | ||||
|                 else if (type == UtilConstants.DateTimeOffsetType) | ||||
|                 { | ||||
|                     return FormatDateTimeOffset(value); | ||||
|                 } | ||||
|                 else if (type == UtilConstants.ByteArrayType) | ||||
|                 { | ||||
|                     string bytesString = "0x" + BitConverter.ToString((byte[])value); | ||||
|                     return bytesString; | ||||
|                 } | ||||
|                 else if (type.IsEnum()) | ||||
|                 { | ||||
|                     if (this.Context.CurrentConnectionConfig.MoreSettings?.TableEnumIsString == true) | ||||
|                     { | ||||
|                         return value.ToSqlValue(); | ||||
|                     } | ||||
|                     else | ||||
|                     { | ||||
|                         return Convert.ToInt64(value); | ||||
|                     } | ||||
|                 } | ||||
|                 else if (type == UtilConstants.BoolType) | ||||
|                 { | ||||
|                     return value.ObjToBool() ? "1" : "0"; | ||||
|                 } | ||||
|                 else if (type == UtilConstants.StringType || type == UtilConstants.ObjType) | ||||
|                 { | ||||
|                     return "'" + value.ToString().ToSqlFilter() + "'"; | ||||
|                 } | ||||
|                 else | ||||
|                 { | ||||
|                     return "'" + value.ToString() + "'"; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         protected override string TomultipleSqlString(List<IGrouping<int, DbColumnInfo>> groupList) | ||||
|         { | ||||
|             Check.Exception(PrimaryKeys == null || PrimaryKeys.Count == 0, " Update List<T> need Primary key"); | ||||
|             int pageSize = 200; | ||||
|             int pageIndex = 1; | ||||
|             int totalRecord = groupList.Count; | ||||
|             int pageCount = (totalRecord + pageSize - 1) / pageSize; | ||||
|             StringBuilder batchUpdateSql = new StringBuilder(); | ||||
|             while (pageCount >= pageIndex) | ||||
|             { | ||||
|                 StringBuilder updateTable = new StringBuilder(); | ||||
|                 string setValues = string.Join(",", groupList.First().Where(it => it.IsPrimarykey == false && (it.IsIdentity == false || (IsOffIdentity && it.IsIdentity))).Select(it => | ||||
|                 { | ||||
|                     if (SetValues.IsValuable()) | ||||
|                     { | ||||
|                         var setValue = SetValues.Where(sv => sv.Key == Builder.GetTranslationColumnName(it.DbColumnName)); | ||||
|                         if (setValue != null && setValue.Any()) | ||||
|                         { | ||||
|                             return setValue.First().Value; | ||||
|                         } | ||||
|                     } | ||||
|                     var result = string.Format("{0}=T.{0}", Builder.GetTranslationColumnName(it.DbColumnName)); | ||||
|                     return result; | ||||
|                 })); | ||||
|                 string tempColumnValue = string.Join(",", groupList.First().Select(it => | ||||
|                 { | ||||
|                     if (SetValues.IsValuable()) | ||||
|                     { | ||||
|                         var setValue = SetValues.Where(sv => sv.Key == Builder.GetTranslationColumnName(it.DbColumnName)); | ||||
|                         if (setValue != null && setValue.Any()) | ||||
|                         { | ||||
|                             return setValue.First().Value; | ||||
|                         } | ||||
|                     } | ||||
|                     var result = Builder.GetTranslationColumnName(it.DbColumnName); | ||||
|                     return result; | ||||
|                 })); | ||||
|                 batchUpdateSql.AppendFormat(SqlTemplateBatch.ToString(), setValues, GetTableNameStringNoWith, TableWithString); | ||||
|                 int i = 0; | ||||
|                 var tableColumnList = this.Context.DbMaintenance.GetColumnInfosByTableName(GetTableNameStringNoWith); | ||||
|                  | ||||
|                 foreach (var columns in groupList.Skip((pageIndex - 1) * pageSize).Take(pageSize).ToList()) | ||||
|                 { | ||||
|                     var isFirst = i == 0; | ||||
|                     if (!isFirst) | ||||
|                     { | ||||
|                         updateTable.Append(SqlTemplateBatchUnion); | ||||
|                     } | ||||
|                     updateTable.Append("\r\n (" + string.Join(",", columns.Select(it => | ||||
|                     { | ||||
|                         var columnInfo = tableColumnList.FirstOrDefault(x => x.DbColumnName.Equals(it.DbColumnName, StringComparison.OrdinalIgnoreCase)); | ||||
|                         var dbType = columnInfo?.DataType; | ||||
|                         if (dbType == null) { | ||||
|                             var typeName = it.PropertyType.Name.ToLower(); | ||||
|                             if (columnInfo==null&&it.PropertyType.IsEnum)  | ||||
|                             { | ||||
|                                 if (this.Context.CurrentConnectionConfig?.MoreSettings?.TableEnumIsString!=true) | ||||
|                                 { | ||||
|                                     typeName = "int"; | ||||
|                                 } | ||||
|                             } | ||||
|                             if (typeName == "int32") | ||||
|                                 typeName = "int"; | ||||
|                             if (typeName == "int64") | ||||
|                                 typeName = "long"; | ||||
|                             if (typeName == "int16") | ||||
|                                 typeName = "short"; | ||||
|                             if (typeName == "boolean") | ||||
|                                 typeName = "bool"; | ||||
|  | ||||
|                             var isAnyType = TDSQLForPGODBCDbBind.MappingTypesConst.Where(x => x.Value.ToString().ToLower() == typeName).Any(); | ||||
|                             if (isAnyType) | ||||
|                             { | ||||
|                                 dbType = TDSQLForPGODBCDbBind.MappingTypesConst.Where(x => x.Value.ToString().ToLower() == typeName).FirstOrDefault().Key; | ||||
|                             } | ||||
|                             else { | ||||
|                                 dbType = "varchar"; | ||||
|                             } | ||||
|                         } | ||||
|                         if(it?.PropertyType?.FullName == "NetTopologySuite.Geometries.Geometry") | ||||
|                         { | ||||
|                             return string.Format(" {0} ", base.GetDbColumn(it, FormatValue(it.Value, it.DbColumnName, i + (pageIndex - 1) * 100000, it)), dbType); | ||||
|                         } | ||||
|                         return string.Format("CAST({0} AS {1})", base.GetDbColumn(it,FormatValue(it.Value,it.DbColumnName,i+(pageIndex-1)*100000,it)), dbType); | ||||
|  | ||||
|                     })) + ")"); | ||||
|                     ++i; | ||||
|                 } | ||||
|                 pageIndex++; | ||||
|                 updateTable.Append("\r\n"); | ||||
|                 string whereString = null; | ||||
|                 if (this.WhereValues.HasValue()) | ||||
|                 { | ||||
|                     foreach (var item in WhereValues) | ||||
|                     { | ||||
|                         var isFirst = whereString == null; | ||||
|                         whereString += (isFirst ? null : " AND "); | ||||
|                         whereString += item; | ||||
|                     } | ||||
|                 } | ||||
|                 else if (PrimaryKeys.HasValue()) | ||||
|                 { | ||||
|                     foreach (var item in PrimaryKeys) | ||||
|                     { | ||||
|                         var isFirst = whereString == null; | ||||
|                         whereString += (isFirst ? null : " AND "); | ||||
|                         whereString += string.Format("{0}.{1}=T.{1}", GetTableNameStringNoWith, Builder.GetTranslationColumnName(item)); | ||||
|                     } | ||||
|                 } | ||||
|                 var format = string.Format(SqlTemplateJoin, updateTable, whereString, tempColumnValue); | ||||
|                 batchUpdateSql.Replace("${0}", format); | ||||
|                 batchUpdateSql.Append(";"); | ||||
|             } | ||||
|             batchUpdateSql = GetBatchUpdateSql(batchUpdateSql); | ||||
|             return batchUpdateSql.ToString(); | ||||
|         } | ||||
|  | ||||
|         private StringBuilder GetBatchUpdateSql(StringBuilder batchUpdateSql) | ||||
|         { | ||||
|             if (ReSetValueBySqlExpListType == null && ReSetValueBySqlExpList != null) | ||||
|             { | ||||
|                 var result = batchUpdateSql.ToString(); | ||||
|                 foreach (var item in ReSetValueBySqlExpList) | ||||
|                 { | ||||
|                     var dbColumnName = item.Value.DbColumnName; | ||||
|                     if (item.Value.Type == ReSetValueBySqlExpListModelType.List) | ||||
|                     { | ||||
|                         result = result.Replace($"{dbColumnName}=T.{dbColumnName}", $"{dbColumnName}={GetTableNameString}.{dbColumnName}{item.Value.Sql}T.{dbColumnName}"); | ||||
|                     } | ||||
|                     else | ||||
|                     { | ||||
|                         if (item.Value?.Sql?.StartsWith("( CASE  WHEN")==true) | ||||
|                         { | ||||
|                             result = result.Replace($"{dbColumnName}=T.{dbColumnName}", $"{dbColumnName}={item.Value.Sql.Replace(" \"", $" {Builder.GetTranslationColumnName(this.TableName)}.\"")}"); | ||||
|                         } | ||||
|                         else | ||||
|                         { | ||||
|                             result = result.Replace($"{dbColumnName}=T.{dbColumnName}", $"{dbColumnName}={item.Value.Sql.Replace(dbColumnName, $"{Builder.GetTranslationColumnName(this.TableName)}.{dbColumnName}")}"); | ||||
|                         } | ||||
|                     } | ||||
|                     batchUpdateSql = new StringBuilder(result); | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|             return batchUpdateSql; | ||||
|         } | ||||
|         protected override string GetJoinUpdate(string columnsString, ref string whereString) | ||||
|         { | ||||
|             if (this.JoinInfos?.Count > 1)  | ||||
|             { | ||||
|                 return this.GetJoinUpdateMany(columnsString,whereString); | ||||
|             } | ||||
|             var formString = $"  {Builder.GetTranslationColumnName(this.TableName)}  AS {Builder.GetTranslationColumnName(this.ShortName)} "; | ||||
|             var joinString = ""; | ||||
|             foreach (var item in this.JoinInfos) | ||||
|             { | ||||
|                 whereString += " AND "+item.JoinWhere; | ||||
|                 joinString += $"\r\n FROM {Builder.GetTranslationColumnName(item.TableName)}  {Builder.GetTranslationColumnName(item.ShortName)} "; | ||||
|             } | ||||
|             var tableName = formString + "\r\n "; | ||||
|             columnsString = columnsString.Replace(Builder.GetTranslationColumnName(this.ShortName)+".","")+joinString;  | ||||
|             return string.Format(SqlTemplate, tableName, columnsString, whereString); | ||||
|         } | ||||
|         private string GetJoinUpdateMany(string columnsString,string where) | ||||
|         { | ||||
|             var formString = $"  {Builder.GetTranslationColumnName(this.TableName)}  AS {Builder.GetTranslationColumnName(this.ShortName)} "; | ||||
|             var joinString = ""; | ||||
|             var i = 0; | ||||
|             foreach (var item in this.JoinInfos) | ||||
|             { | ||||
|                 var whereString = " ON " + item.JoinWhere; | ||||
|                 joinString += $"\r\n JOIN {Builder.GetTranslationColumnName(item.TableName)}  {Builder.GetTranslationColumnName(item.ShortName)} "; | ||||
|                 joinString = joinString + whereString; | ||||
|                 i++; | ||||
|             } | ||||
|             var tableName = Builder.GetTranslationColumnName(this.TableName) + "\r\n "; | ||||
|             columnsString = columnsString.Replace(Builder.GetTranslationColumnName(this.ShortName) + ".", "") + $" FROM {Builder.GetTranslationColumnName(this.TableName)} {Builder.GetTranslationColumnName(this.ShortName)}\r\n " + joinString; | ||||
|             return string.Format(SqlTemplate, tableName, columnsString, where); | ||||
|         } | ||||
|         public override string FormatDateTimeOffset(object value) | ||||
|         { | ||||
|             return "'" + ((DateTimeOffset)value).ToString("o") + "'"; | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,370 @@ | ||||
| using System; | ||||
| using System.Collections.Generic; | ||||
| using System.Data; | ||||
| using System.Data.Common; | ||||
| using System.Linq; | ||||
| using System.Text; | ||||
| using System.Threading.Tasks; | ||||
| using System.Xml.Linq; | ||||
| using System.Data.Odbc; | ||||
| using System.Text.RegularExpressions; | ||||
| using System.Data.SqlTypes; | ||||
|  | ||||
| namespace SqlSugar.TDSQLForPGODBC | ||||
| { | ||||
|     /// <summary> | ||||
|     /// 适配TDSQL的ODBC驱动 | ||||
|     /// </summary> | ||||
|     public class TDSQLForPGODBCProvider : AdoProvider | ||||
|     { | ||||
|         public TDSQLForPGODBCProvider() { } | ||||
|         public override IDbConnection Connection | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 if (base._DbConnection == null) | ||||
|                 { | ||||
|                     try | ||||
|                     { | ||||
|                         base._DbConnection = new OdbcConnection(base.Context.CurrentConnectionConfig.ConnectionString); | ||||
|                     } | ||||
|                     catch (Exception ex) | ||||
|                     { | ||||
|                         throw ex; | ||||
|                     } | ||||
|                 } | ||||
|                 return base._DbConnection; | ||||
|             } | ||||
|             set | ||||
|             { | ||||
|                 base._DbConnection = value; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         public string SplitCommandTag => UtilConstants.ReplaceCommaKey.Replace("{", "").Replace("}", ""); | ||||
|  | ||||
|  | ||||
|         public override object GetScalar(string sql, params SugarParameter[] parameters) | ||||
|         { | ||||
|             if (this.Context.Ado.Transaction != null) | ||||
|             { | ||||
|                 return _GetScalar(sql, parameters); | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 try | ||||
|                 { | ||||
|                     this.Context.Ado.BeginTran(); | ||||
|                     var result = _GetScalar(sql, parameters); | ||||
|                     this.Context.Ado.CommitTran(); | ||||
|                     return result; | ||||
|                 } | ||||
|                 catch (Exception ex) | ||||
|                 { | ||||
|                     this.Context.Ado.RollbackTran(); | ||||
|                     throw ex; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         public override async Task<object> GetScalarAsync(string sql, params SugarParameter[] parameters) | ||||
|         { | ||||
|             if (this.Context.Ado.Transaction != null) | ||||
|             { | ||||
|                 return await _GetScalarAsync(sql, parameters); | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 try | ||||
|                 { | ||||
|                     this.Context.Ado.BeginTran(); | ||||
|                     var result = await _GetScalarAsync(sql, parameters); | ||||
|                     this.Context.Ado.CommitTran(); | ||||
|                     return result; | ||||
|                 } | ||||
|                 catch (Exception ex) | ||||
|                 { | ||||
|                     this.Context.Ado.RollbackTran(); | ||||
|                     throw ex; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         private object _GetScalar(string sql, SugarParameter[] parameters) | ||||
|         { | ||||
|             if (sql == null) throw new Exception("sql is null"); | ||||
|             if (sql.IndexOf(this.SplitCommandTag) > 0) | ||||
|             { | ||||
|                 var sqlParts = Regex.Split(sql, this.SplitCommandTag).Where(it => !string.IsNullOrEmpty(it)).ToList(); | ||||
|                 object result = 0; | ||||
|                 foreach (var item in sqlParts) | ||||
|                 { | ||||
|                     if (item.TrimStart('\r').TrimStart('\n') != "") | ||||
|                     { | ||||
|                         result = base.GetScalar(item, parameters); | ||||
|                     } | ||||
|                 } | ||||
|                 return result; | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 return base.GetScalar(sql, parameters); | ||||
|             } | ||||
|         } | ||||
|         private async Task<object> _GetScalarAsync(string sql, SugarParameter[] parameters) | ||||
|         { | ||||
|             if (sql == null) throw new Exception("sql is null"); | ||||
|             if (sql.IndexOf(this.SplitCommandTag) > 0) | ||||
|             { | ||||
|                 var sqlParts = Regex.Split(sql, this.SplitCommandTag).Where(it => !string.IsNullOrEmpty(it)).ToList(); | ||||
|                 object result = 0; | ||||
|                 foreach (var item in sqlParts) | ||||
|                 { | ||||
|                     if (item.TrimStart('\r').TrimStart('\n') != "") | ||||
|                     { | ||||
|                         result = await base.GetScalarAsync(item, parameters); | ||||
|                     } | ||||
|                 } | ||||
|                 return result; | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 return await base.GetScalarAsync(sql, parameters); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         public override int ExecuteCommand(string sql, SugarParameter[] parameters) | ||||
|         { | ||||
|             if (sql == null) throw new Exception("sql is null"); | ||||
|             if (sql.IndexOf(this.SplitCommandTag) > 0) | ||||
|             { | ||||
|                 var sqlParts = Regex.Split(sql, this.SplitCommandTag).Where(it => !string.IsNullOrEmpty(it)).ToList(); | ||||
|                 int result = 0; | ||||
|                 foreach (var item in sqlParts) | ||||
|                 { | ||||
|                     if (item.TrimStart('\r').TrimStart('\n') != "") | ||||
|                     { | ||||
|                         result += base.ExecuteCommand(item, parameters); | ||||
|                     } | ||||
|                 } | ||||
|                 return result; | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 return base.ExecuteCommand(sql, parameters); | ||||
|             } | ||||
|         } | ||||
|         public override async Task<int> ExecuteCommandAsync(string sql, SugarParameter[] parameters) | ||||
|         { | ||||
|             if (sql == null) throw new Exception("sql is null"); | ||||
|             if (sql.IndexOf(this.SplitCommandTag) > 0) | ||||
|             { | ||||
|                 var sqlParts = Regex.Split(sql, this.SplitCommandTag).Where(it => !string.IsNullOrEmpty(it)).ToList(); | ||||
|                 int result = 0; | ||||
|                 foreach (var item in sqlParts) | ||||
|                 { | ||||
|                     if (item.TrimStart('\r').TrimStart('\n') != "") | ||||
|                     { | ||||
|                         result += await base.ExecuteCommandAsync(item, parameters); | ||||
|                     } | ||||
|                 } | ||||
|                 return result; | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 return base.ExecuteCommand(sql, parameters); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Only Odbc | ||||
|         /// </summary> | ||||
|         /// <param name="transactionName"></param> | ||||
|         public override void BeginTran(string transactionName) | ||||
|         { | ||||
|             CheckConnection(); | ||||
|             base.Transaction = ((OdbcConnection)this.Connection).BeginTransaction(); | ||||
|         } | ||||
|         /// <summary> | ||||
|         /// Only Odbc | ||||
|         /// </summary> | ||||
|         /// <param name="iso"></param> | ||||
|         /// <param name="transactionName"></param> | ||||
|         public override void BeginTran(IsolationLevel iso, string transactionName) | ||||
|         { | ||||
|             CheckConnection(); | ||||
|             base.Transaction = ((OdbcConnection)this.Connection).BeginTransaction(iso); | ||||
|         } | ||||
|  | ||||
|         public override IDataAdapter GetAdapter() | ||||
|         { | ||||
|             return new TDSQLForPGODBCAdapter(); | ||||
|         } | ||||
|         public override DbCommand GetCommand(string sql, SugarParameter[] parameters) | ||||
|         { | ||||
|             var helper = new TDSQLForPGODBCInsertBuilder(); | ||||
|             helper.Context = this.Context; | ||||
|             List<SugarParameter> orderParameters = new List<SugarParameter>(); | ||||
|             if (parameters.HasValue()) | ||||
|             { | ||||
|                 foreach (var p in parameters) | ||||
|                 { | ||||
|                     if (!p.ParameterName.StartsWith(this.SqlParameterKeyWord)) | ||||
|                     { | ||||
|                         p.ParameterName = this.SqlParameterKeyWord + p.ParameterName; | ||||
|                     } | ||||
|                 } | ||||
|                 orderParameters = parameters.Where(it => sql.Contains(it.ParameterName)) | ||||
|                                            .Select(it => new { p = it, sort = GetSortId(sql, it) }) | ||||
|                                            .OrderBy(it => it.sort) | ||||
|                                            .Where(it => it.sort != 0) | ||||
|                                            .Select(it => it.p) | ||||
|                                            .ToList(); | ||||
|                 foreach (var param in parameters.OrderByDescending(it => it.ParameterName.Length)) | ||||
|                 { | ||||
|                     sql = sql.Replace(param.ParameterName, "?"); | ||||
|                 } | ||||
|  | ||||
|             } | ||||
|             OdbcCommand sqlCommand = new OdbcCommand(sql, (OdbcConnection)this.Connection); | ||||
|             sqlCommand.CommandType = this.CommandType; | ||||
|             sqlCommand.CommandTimeout = this.CommandTimeOut; | ||||
|             if (this.Transaction != null) | ||||
|             { | ||||
|                 sqlCommand.Transaction = (OdbcTransaction)this.Transaction; | ||||
|             } | ||||
|             if (orderParameters.HasValue()) | ||||
|             { | ||||
|                 OdbcParameter[] ipars = GetSqlParameter(orderParameters.ToArray()); | ||||
|                 sqlCommand.Parameters.AddRange(ipars); | ||||
|             } | ||||
|             CheckConnection(); | ||||
|             return sqlCommand; | ||||
|         } | ||||
|  | ||||
|         private static int GetSortId(string sql, SugarParameter it) | ||||
|         { | ||||
|             return new List<int>() { | ||||
|                                                   0, | ||||
|                                                   sql.IndexOf(it.ParameterName+")"), | ||||
|                                                   sql.IndexOf(it.ParameterName+" "), | ||||
|                                                   sql.IndexOf(it.ParameterName+"="), | ||||
|                                                   sql.IndexOf(it.ParameterName+"+"), | ||||
|                                                   sql.IndexOf(it.ParameterName+"-"), | ||||
|                                                   sql.IndexOf(it.ParameterName+";"), | ||||
|                                                   sql.IndexOf(it.ParameterName+","), | ||||
|                                                   sql.IndexOf(it.ParameterName+"*"), | ||||
|                                                   sql.IndexOf(it.ParameterName+"/"), | ||||
|                                                   sql.IndexOf(it.ParameterName+"|"), | ||||
|                                                   sql.IndexOf(it.ParameterName+"&"), | ||||
|                                                   sql.EndsWith(it.ParameterName)?sql.IndexOf(it.ParameterName):0 | ||||
|                                            }.Max(); | ||||
|         } | ||||
|  | ||||
|         public override void SetCommandToAdapter(IDataAdapter dataAdapter, DbCommand command) | ||||
|         { | ||||
|             ((TDSQLForPGODBCAdapter)dataAdapter).SelectCommand = (OdbcCommand)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 new OdbcParameter[] { }; | ||||
|             OdbcParameter[] result = new OdbcParameter[parameters.Length]; | ||||
|             int index = 0; | ||||
|             foreach (var parameter in parameters) | ||||
|             { | ||||
|                 if (parameter.Value == null) parameter.Value = DBNull.Value; | ||||
|                 var sqlParameter = new OdbcParameter(); | ||||
|                 sqlParameter.ParameterName = parameter.ParameterName; | ||||
|                 //sqlParameter.UdtTypeName = parameter.UdtTypeName; | ||||
|                 sqlParameter.Size = parameter.Size; | ||||
|                 sqlParameter.Value = parameter.Value; | ||||
|                 sqlParameter.DbType = parameter.DbType; | ||||
|                 sqlParameter.Direction = parameter.Direction; | ||||
|                 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); | ||||
|                 } | ||||
|                 ++index; | ||||
|             } | ||||
|             return result; | ||||
|         } | ||||
|         /// <summary> | ||||
|         /// if mysql return MySqlParameter[] pars | ||||
|         /// if sqlerver return SqlParameter[] pars ... | ||||
|         /// </summary> | ||||
|         /// <param name="parameters"></param> | ||||
|         /// <returns></returns> | ||||
|         public OdbcParameter[] GetSqlParameter(params SugarParameter[] parameters) | ||||
|         { | ||||
|             if (parameters == null || parameters.Length == 0) return null; | ||||
|             OdbcParameter[] result = new OdbcParameter[parameters.Length]; | ||||
|             int index = 0; | ||||
|             foreach (var parameter in parameters) | ||||
|             { | ||||
|                 if (parameter.Value == null) parameter.Value = DBNull.Value; | ||||
|                 var sqlParameter = new OdbcParameter(); | ||||
|                 sqlParameter.ParameterName = parameter.ParameterName; | ||||
|                 //sqlParameter.UdtTypeName = parameter.UdtTypeName; | ||||
|                 sqlParameter.Size = parameter.Size; | ||||
|                 sqlParameter.Value = parameter.Value; | ||||
|                 sqlParameter.DbType = GetDbType(parameter); | ||||
|                 var isTime = parameter.DbType == System.Data.DbType.Time; | ||||
|                 if (isTime) | ||||
|                 { | ||||
|                     sqlParameter.Value = DateTime.Parse(parameter.Value?.ToString()).TimeOfDay; | ||||
|                 } | ||||
|                 if (sqlParameter.Value != null && sqlParameter.Value != DBNull.Value && sqlParameter.DbType == System.Data.DbType.DateTime) | ||||
|                 { | ||||
|                     var date = Convert.ToDateTime(sqlParameter.Value); | ||||
|                     if (date == DateTime.MinValue) | ||||
|                     { | ||||
|                         sqlParameter.Value = UtilMethods.GetMinDate(this.Context.CurrentConnectionConfig); | ||||
|                     } | ||||
|                 } | ||||
|                 if (parameter.Direction == 0) | ||||
|                 { | ||||
|                     parameter.Direction = ParameterDirection.Input; | ||||
|                 } | ||||
|                 sqlParameter.Direction = parameter.Direction; | ||||
|                 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); | ||||
|                 } | ||||
|  | ||||
|                 ++index; | ||||
|             } | ||||
|             return result; | ||||
|         } | ||||
|  | ||||
|         private static System.Data.DbType GetDbType(SugarParameter parameter) | ||||
|         { | ||||
|             if (parameter.DbType == System.Data.DbType.UInt16) | ||||
|             { | ||||
|                 return System.Data.DbType.Int16; | ||||
|             } | ||||
|             else if (parameter.DbType == System.Data.DbType.UInt32) | ||||
|             { | ||||
|                 return System.Data.DbType.Int32; | ||||
|             } | ||||
|             else if (parameter.DbType == System.Data.DbType.UInt64) | ||||
|             { | ||||
|                 return System.Data.DbType.Int64; | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 return parameter.DbType; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,64 @@ | ||||
| using System; | ||||
| using System.Collections.Generic; | ||||
| using System.Linq; | ||||
| using System.Text; | ||||
| namespace SqlSugar.TDSQLForPGODBC | ||||
| { | ||||
|     internal static partial class ErrorMessage | ||||
|     { | ||||
|         internal static LanguageType SugarLanguageType { get; set; } = LanguageType.Default; | ||||
|         internal static string ObjNotExist | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return GetThrowMessage("{0} does not exist.", | ||||
|                                        "{0}不存在。"); | ||||
|             } | ||||
|         } | ||||
|         internal static string EntityMappingError | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return GetThrowMessage("Entity mapping error.{0}", | ||||
|                                        "实体与表映射出错。{0}"); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         public static string NotSupportedDictionary | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return GetThrowMessage("This type of Dictionary is not supported for the time being. You can try Dictionary<string, string>, or contact the author!!", | ||||
|                                        "暂时不支持该类型的Dictionary 你可以试试 Dictionary<string ,string>或者联系作者!!"); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         public static string NotSupportedArray | ||||
|         { | ||||
|             get | ||||
|             { | ||||
|                 return GetThrowMessage("This type of Array is not supported for the time being. You can try object[] or contact the author!!", | ||||
|                                        "暂时不支持该类型的Array 你可以试试 object[] 或者联系作者!!"); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         internal static string GetThrowMessage(string enMessage, string cnMessage, params string[] args) | ||||
|         { | ||||
|             if (SugarLanguageType == LanguageType.Default) | ||||
|             { | ||||
|                 List<string> formatArgs = new List<string>() { enMessage, cnMessage }; | ||||
|                 formatArgs.AddRange(args); | ||||
|                 return string.Format(@"中文提示 : {1} | ||||
| English Message : {0}", formatArgs.ToArray()); | ||||
|             } | ||||
|             else if (SugarLanguageType == LanguageType.English) | ||||
|             { | ||||
|                 return enMessage; | ||||
|             } | ||||
|             else  | ||||
|             { | ||||
|                 return cnMessage; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,20 @@ | ||||
| using System; | ||||
| using System.Collections.Generic; | ||||
| using System.Linq; | ||||
| using System.Linq.Expressions; | ||||
| using System.Text; | ||||
|  | ||||
| namespace SqlSugar.TDSQLForPGODBC | ||||
| { | ||||
|     internal class ExpressionConst | ||||
|     { | ||||
|         public const string Const = "Const"; | ||||
|         public const string FormatSymbol = "{0}"; | ||||
|         public const string RightParenthesis = ")"; | ||||
|         public const string LeftParenthesis = "("; | ||||
|         public const string MethodConst = "MethodConst"; | ||||
|         public const string SqlFuncFullName = "SqlSugar.SqlFunc"; | ||||
|         public const string BinaryFormatString = " ( {0} {1} {2} ) "; | ||||
|         public const string ExpressionReplace = "46450BDC-77B7-4025-B2A6-3F048CA85AD0"; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										70
									
								
								Src/Asp.NetCore2/SqlSugar.TDSQLForPGODBC/Tools/FileHelper.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										70
									
								
								Src/Asp.NetCore2/SqlSugar.TDSQLForPGODBC/Tools/FileHelper.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,70 @@ | ||||
| using System; | ||||
| using System.Collections.Generic; | ||||
| using System.IO; | ||||
| using System.Linq; | ||||
| using System.Text; | ||||
|  | ||||
| namespace SqlSugar.TDSQLForPGODBC | ||||
| { | ||||
|     internal class FileHelper | ||||
|     { | ||||
|         public static void CreateFile(string filePath, string text, Encoding encoding) | ||||
|         { | ||||
|             try | ||||
|             { | ||||
|                 if (IsExistFile(filePath)) | ||||
|                 { | ||||
|                     DeleteFile(filePath); | ||||
|                 } | ||||
|                 if (!IsExistFile(filePath)) | ||||
|                 { | ||||
|                     string directoryPath = GetDirectoryFromFilePath(filePath); | ||||
|                     CreateDirectory(directoryPath); | ||||
|  | ||||
|                     //Create File | ||||
|                     FileInfo file = new FileInfo(filePath); | ||||
|                     using (FileStream stream = file.Create()) | ||||
|                     { | ||||
|                         using (StreamWriter writer = new StreamWriter(stream, encoding)) | ||||
|                         { | ||||
|                             writer.Write(text); | ||||
|                             writer.Flush(); | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|             catch(Exception ex) | ||||
|             { | ||||
|                 throw ex; | ||||
|             } | ||||
|         } | ||||
|         public static bool IsExistDirectory(string directoryPath) | ||||
|         { | ||||
|             return Directory.Exists(directoryPath); | ||||
|         } | ||||
|         public static void CreateDirectory(string directoryPath) | ||||
|         { | ||||
|             if (!IsExistDirectory(directoryPath)) | ||||
|             { | ||||
|                 Directory.CreateDirectory(directoryPath); | ||||
|             } | ||||
|         } | ||||
|         public static void DeleteFile(string filePath) | ||||
|         { | ||||
|             if (IsExistFile(filePath)) | ||||
|             { | ||||
|                 File.Delete(filePath); | ||||
|             } | ||||
|         } | ||||
|         public static string GetDirectoryFromFilePath(string filePath) | ||||
|         { | ||||
|             FileInfo file = new FileInfo(filePath); | ||||
|             DirectoryInfo directory = file.Directory; | ||||
|             return directory.FullName; | ||||
|         } | ||||
|         public static bool IsExistFile(string filePath) | ||||
|         { | ||||
|             return File.Exists(filePath); | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,79 @@ | ||||
| using System; | ||||
| using System.Collections.Generic; | ||||
| using System.Dynamic; | ||||
| using System.Linq; | ||||
| using System.Text; | ||||
| namespace SqlSugar.TDSQLForPGODBC | ||||
| { | ||||
|     internal static class UtilConstants | ||||
|     { | ||||
|         public const string Dot = "."; | ||||
|         public const char DotChar = '.'; | ||||
|         internal const string Space = " "; | ||||
|         internal const char SpaceChar = ' '; | ||||
|         internal const string AssemblyName = "SqlSugar"; | ||||
|         internal static string ReplaceKey = "{" + Guid.NewGuid() + "}"; | ||||
|         internal const string ReplaceCommaKey = "{112A689B-17A1-4A06-9D27-A39EAB8BC3D5}"; | ||||
|  | ||||
|         internal static Type UShortType = typeof(ushort); | ||||
|         internal static Type ULongType = typeof(ulong); | ||||
|         internal static Type UIntType = typeof(uint); | ||||
|         internal static Type IntType = typeof(int); | ||||
|         internal static Type LongType = typeof(long); | ||||
|         internal static Type GuidType = typeof(Guid); | ||||
|         internal static Type BoolType = typeof(bool); | ||||
|         internal static Type BoolTypeNull = typeof(bool?); | ||||
|         internal static Type ByteType = typeof(Byte); | ||||
|         internal static Type SByteType = typeof(sbyte); | ||||
|         internal static Type ObjType = typeof(object); | ||||
|         internal static Type DobType = typeof(double); | ||||
|         internal static Type FloatType = typeof(float); | ||||
|         internal static Type ShortType = typeof(short); | ||||
|         internal static Type DecType = typeof(decimal); | ||||
|         internal static Type StringType = typeof(string); | ||||
|         internal static Type DateType = typeof(DateTime); | ||||
|         internal static Type DateTimeOffsetType = typeof(DateTimeOffset); | ||||
|         internal static Type TimeSpanType = typeof(TimeSpan); | ||||
|         internal static Type ByteArrayType = typeof(byte[]); | ||||
|         internal static Type ModelType = typeof(ModelContext); | ||||
|         internal static Type DynamicType = typeof(ExpandoObject); | ||||
|         internal static Type Dicii = typeof(KeyValuePair<int, int>); | ||||
|         internal static Type DicIS = typeof(KeyValuePair<int, string>); | ||||
|         internal static Type DicSi = typeof(KeyValuePair<string, int>); | ||||
|         internal static Type DicSS = typeof(KeyValuePair<string, string>); | ||||
|         internal static Type DicOO = typeof(KeyValuePair<object, object>); | ||||
|         internal static Type DicSo = typeof(KeyValuePair<string, object>); | ||||
|         internal static Type DicArraySS = typeof(Dictionary<string, string>); | ||||
|         internal static Type DicArraySO = typeof(Dictionary<string, object>); | ||||
|  | ||||
|         public static Type SqlConvertType = typeof(SqlSugar.DbConvert.NoParameterCommonPropertyConvert); | ||||
|  | ||||
|         public static Type SugarType = typeof(SqlSugarProvider); | ||||
|  | ||||
|  | ||||
|         internal static Type[] NumericalTypes = new Type[] | ||||
|         { | ||||
|             typeof(int), | ||||
|             typeof(uint), | ||||
|             typeof(byte), | ||||
|             typeof(sbyte), | ||||
|             typeof(long), | ||||
|             typeof(ulong), | ||||
|             typeof(short), | ||||
|             typeof(ushort), | ||||
|         }; | ||||
|  | ||||
|  | ||||
|         internal static string[] DateTypeStringList = new string[] | ||||
|         { | ||||
|                 "Year", | ||||
|                 "Month", | ||||
|                 "Day", | ||||
|                 "Hour", | ||||
|                 "Second" , | ||||
|                 "Minute", | ||||
|                 "Millisecond", | ||||
|                 "Date" | ||||
|         }; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,37 @@ | ||||
| using System; | ||||
| using System.Collections.Generic; | ||||
| using System.Linq; | ||||
| using System.Text; | ||||
| namespace SqlSugar.TDSQLForPGODBC | ||||
| { | ||||
|     /// <summary> | ||||
|     ///Common Extensions for external users | ||||
|     /// </summary> | ||||
|     public static class UtilExtensions | ||||
|     { | ||||
|         public static string ToLower(this string value, bool isLower)  | ||||
|         { | ||||
|             if (isLower)  | ||||
|             { | ||||
|                 return value.ObjToString().ToLower(); | ||||
|             } | ||||
|             return value.ObjToString(); | ||||
|         } | ||||
|         public static string ToUpper(this string value, bool isAutoToUpper) | ||||
|         { | ||||
|             if (value == null) return null; | ||||
|             if (isAutoToUpper == false) return value; | ||||
|             return value.ToUpper(); | ||||
|         } | ||||
|  | ||||
|         public static string GetN(this SqlSugarProvider Context)  | ||||
|         { | ||||
|             var N = "N"; | ||||
|             if (Context.CurrentConnectionConfig.MoreSettings != null && Context.CurrentConnectionConfig.MoreSettings.DisableNvarchar) | ||||
|             { | ||||
|                 N = ""; | ||||
|             } | ||||
|             return N; | ||||
|         } | ||||
|     } | ||||
| } | ||||
							
								
								
									
										1751
									
								
								Src/Asp.NetCore2/SqlSugar.TDSQLForPGODBC/Tools/UtilMethods.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1751
									
								
								Src/Asp.NetCore2/SqlSugar.TDSQLForPGODBC/Tools/UtilMethods.cs
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -0,0 +1,172 @@ | ||||
| using System; | ||||
| using System.Collections.Generic; | ||||
| using System.Linq; | ||||
| using System.Text; | ||||
| using System.Text.RegularExpressions; | ||||
| namespace SqlSugar.TDSQLForPGODBC | ||||
| { | ||||
|     internal static class ValidateExtensions | ||||
|     { | ||||
|         public static bool IsInRange(this int thisValue, int begin, int end) | ||||
|         { | ||||
|             return thisValue >= begin && thisValue <= end; | ||||
|         } | ||||
|  | ||||
|         public static bool IsInRange(this DateTime thisValue, DateTime begin, DateTime end) | ||||
|         { | ||||
|             return thisValue >= begin && thisValue <= end; | ||||
|         } | ||||
|  | ||||
|         public static bool IsIn<T>(this T thisValue, params T[] values) | ||||
|         { | ||||
|             return values.Contains(thisValue); | ||||
|         } | ||||
|  | ||||
|         public static bool IsContainsIn(this string thisValue, params string[] inValues) | ||||
|         { | ||||
|             return inValues.Any(it => thisValue.Contains(it)); | ||||
|         } | ||||
|  | ||||
|         public static bool IsNullOrEmpty(this object thisValue) | ||||
|         { | ||||
|             if (thisValue == null || thisValue == DBNull.Value) return true; | ||||
|             return thisValue.ToString() == ""; | ||||
|         } | ||||
|  | ||||
|         public static bool IsNullOrEmpty(this Guid? thisValue) | ||||
|         { | ||||
|             if (thisValue == null) return true; | ||||
|             return thisValue == Guid.Empty; | ||||
|         } | ||||
|    | ||||
|         public static bool IsNullOrEmpty(this Guid thisValue) | ||||
|         { | ||||
|             if (thisValue == null) return true; | ||||
|             return thisValue == Guid.Empty; | ||||
|         } | ||||
|  | ||||
|         public static bool IsNullOrEmpty(this IEnumerable<object> thisValue) | ||||
|         { | ||||
|             if (thisValue == null || thisValue.Count() == 0) return true; | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         public static bool HasValue(this object thisValue) | ||||
|         { | ||||
|             if (thisValue == null || thisValue == DBNull.Value) return false; | ||||
|             return thisValue.ToString() != ""; | ||||
|         } | ||||
|  | ||||
|         public static bool HasValue(this IEnumerable<object> thisValue) | ||||
|         { | ||||
|             if (thisValue == null || thisValue.Count() == 0) return false; | ||||
|             return true; | ||||
|         } | ||||
|  | ||||
|         public static bool IsValuable(this IEnumerable<KeyValuePair<string,string>> thisValue) | ||||
|         { | ||||
|             if (thisValue == null || thisValue.Count() == 0) return false; | ||||
|             return true; | ||||
|         } | ||||
|  | ||||
|         public static bool IsZero(this object thisValue) | ||||
|         { | ||||
|             return (thisValue == null || thisValue.ToString() == "0"); | ||||
|         } | ||||
|  | ||||
|         public static bool IsInt(this object thisValue) | ||||
|         { | ||||
|             if (thisValue == null) return false; | ||||
|             return Regex.IsMatch(thisValue.ToString(), @"^\d+$"); | ||||
|         } | ||||
|  | ||||
|         /// <returns></returns> | ||||
|         public static bool IsNoInt(this object thisValue) | ||||
|         { | ||||
|             if (thisValue == null) return true; | ||||
|             return !Regex.IsMatch(thisValue.ToString(), @"^\d+$"); | ||||
|         } | ||||
|  | ||||
|         public static bool IsMoney(this object thisValue) | ||||
|         { | ||||
|             if (thisValue == null) return false; | ||||
|             double outValue = 0; | ||||
|             return double.TryParse(thisValue.ToString(), out outValue); | ||||
|         } | ||||
|         public static bool IsGuid(this object thisValue) | ||||
|         { | ||||
|             if (thisValue == null) return false; | ||||
|             Guid outValue = Guid.Empty; | ||||
|             return Guid.TryParse(thisValue.ToString(), out outValue); | ||||
|         } | ||||
|  | ||||
|         public static bool IsDate(this object thisValue) | ||||
|         { | ||||
|             if (thisValue == null) return false; | ||||
|             DateTime outValue = DateTime.MinValue; | ||||
|             return DateTime.TryParse(thisValue.ToString(), out outValue); | ||||
|         } | ||||
|  | ||||
|         public static bool IsEamil(this object thisValue) | ||||
|         { | ||||
|             if (thisValue == null) return false; | ||||
|             return Regex.IsMatch(thisValue.ToString(), @"^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$"); | ||||
|         } | ||||
|  | ||||
|         public static bool IsMobile(this object thisValue) | ||||
|         { | ||||
|             if (thisValue == null) return false; | ||||
|             return Regex.IsMatch(thisValue.ToString(), @"^\d{11}$"); | ||||
|         } | ||||
|  | ||||
|         public static bool IsTelephone(this object thisValue) | ||||
|         { | ||||
|             if (thisValue == null) return false; | ||||
|             return System.Text.RegularExpressions.Regex.IsMatch(thisValue.ToString(), @"^(\(\d{3,4}\)|\d{3,4}-|\s)?\d{8}$"); | ||||
|  | ||||
|         } | ||||
|  | ||||
|         public static bool IsIDcard(this object thisValue) | ||||
|         { | ||||
|             if (thisValue == null) return false; | ||||
|             return System.Text.RegularExpressions.Regex.IsMatch(thisValue.ToString(), @"^(\d{15}$|^\d{18}$|^\d{17}(\d|X|x))$"); | ||||
|         } | ||||
|  | ||||
|         public static bool IsFax(this object thisValue) | ||||
|         { | ||||
|             if (thisValue == null) return false; | ||||
|             return System.Text.RegularExpressions.Regex.IsMatch(thisValue.ToString(), @"^[+]{0,1}(\d){1,3}[ ]?([-]?((\d)|[ ]){1,12})+$"); | ||||
|         } | ||||
|  | ||||
|         public static bool IsMatch(this object thisValue, string pattern) | ||||
|         { | ||||
|             if (thisValue == null) return false; | ||||
|             Regex reg = new Regex(pattern); | ||||
|             return reg.IsMatch(thisValue.ToString()); | ||||
|         } | ||||
|         public static bool IsAnonymousType(this Type type) | ||||
|         { | ||||
|             string typeName = type.Name; | ||||
|             return typeName.Contains("<>") && typeName.Contains("__") && typeName.Contains("AnonymousType"); | ||||
|         } | ||||
|         public static bool IsCollectionsList(this string thisValue) | ||||
|         { | ||||
|             return (thisValue + "").StartsWith("System.Collections.Generic.List")|| (thisValue + "").StartsWith("System.Collections.Generic.IEnumerable"); | ||||
|         } | ||||
|         public static bool IsStringArray(this string thisValue) | ||||
|         { | ||||
|             return (thisValue + "").IsMatch(@"System\.[a-z,A-Z,0-9]+?\[\]"); | ||||
|         } | ||||
|         public static bool IsEnumerable(this string thisValue) | ||||
|         { | ||||
|             return (thisValue + "").StartsWith("System.Linq.Enumerable"); | ||||
|         } | ||||
|  | ||||
|         public static Type StringType = typeof (string); | ||||
|  | ||||
|         public static bool IsClass(this Type thisValue) | ||||
|         { | ||||
|             return thisValue != StringType && thisValue.IsEntity()&&thisValue!=UtilConstants.ByteArrayType; | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,192 @@ | ||||
| using System; | ||||
| using System.Collections.Generic; | ||||
| using System.Linq; | ||||
| using System.Linq.Expressions; | ||||
| using System.Text; | ||||
| namespace SqlSugar.TDSQLForPGODBC | ||||
| { | ||||
|     internal static class UtilConvert | ||||
|     { | ||||
|         public static int ObjToInt(this object thisValue) | ||||
|         { | ||||
|             int reval = 0; | ||||
|             if (thisValue == null) return 0; | ||||
|             if (thisValue is Enum) | ||||
|             { | ||||
|                 return Convert.ToInt32(thisValue); | ||||
|             } | ||||
|             if (thisValue != null && thisValue != DBNull.Value && int.TryParse(thisValue.ToString(), out reval)) | ||||
|             { | ||||
|                 return reval; | ||||
|             } | ||||
|             return reval; | ||||
|         } | ||||
|  | ||||
|         public static long ObjToLong(this object thisValue) | ||||
|         { | ||||
|             long reval = 0; | ||||
|             if (thisValue == null) return 0; | ||||
|             if (thisValue is Enum) | ||||
|             { | ||||
|                 return Convert.ToInt64(thisValue); | ||||
|             } | ||||
|             if (thisValue != null && thisValue != DBNull.Value && long.TryParse(thisValue.ToString(), out reval)) | ||||
|             { | ||||
|                 return reval; | ||||
|             } | ||||
|             return reval; | ||||
|         } | ||||
|  | ||||
|         public static int ObjToInt(this object thisValue, int errorValue) | ||||
|         { | ||||
|             int reval = 0; | ||||
|             if (thisValue is Enum) | ||||
|             { | ||||
|                 return (int)thisValue; | ||||
|             } | ||||
|             if (thisValue != null && thisValue != DBNull.Value && int.TryParse(thisValue.ToString(), out reval)) | ||||
|             { | ||||
|                 return reval; | ||||
|             } | ||||
|             return errorValue; | ||||
|         } | ||||
|  | ||||
|         public static double ObjToMoney(this object thisValue) | ||||
|         { | ||||
|             double reval = 0; | ||||
|             if (thisValue != null && thisValue != DBNull.Value && double.TryParse(thisValue.ToString(), out reval)) | ||||
|             { | ||||
|                 return reval; | ||||
|             } | ||||
|             return 0; | ||||
|         } | ||||
|  | ||||
|         public static double ObjToMoney(this object thisValue, double errorValue) | ||||
|         { | ||||
|             double reval = 0; | ||||
|             if (thisValue != null && thisValue != DBNull.Value && double.TryParse(thisValue.ToString(), out reval)) | ||||
|             { | ||||
|                 return reval; | ||||
|             } | ||||
|             return errorValue; | ||||
|         } | ||||
|         public static bool EqualCase(this string thisValue,string equalValue)  | ||||
|         { | ||||
|             if ( thisValue!=null && equalValue != null) | ||||
|             { | ||||
|                 return thisValue.ToLower() == equalValue.ToLower(); | ||||
|             } | ||||
|             else  | ||||
|             { | ||||
|                 return thisValue == equalValue; | ||||
|             } | ||||
|         } | ||||
|         public static string ObjToString(this object thisValue,Func<DateTime,string> formatTime) | ||||
|         { | ||||
|             if (formatTime != null&&thisValue is DateTime) | ||||
|             { | ||||
|                 var dt = Convert.ToDateTime(thisValue); | ||||
|                 return formatTime(dt); | ||||
|             } | ||||
|             else  | ||||
|             { | ||||
|                 return thisValue.ObjToStringNoTrim(); | ||||
|             } | ||||
|         } | ||||
|         public static string ObjToString(this object thisValue) | ||||
|         { | ||||
|             if (thisValue != null) return thisValue.ToString().Trim(); | ||||
|             return ""; | ||||
|         } | ||||
|         public static string ObjToStringNoTrim(this object thisValue) | ||||
|         { | ||||
|             if (thisValue != null) return thisValue.ToString(); | ||||
|             return ""; | ||||
|         } | ||||
|         public static string ObjToStringNew(this object thisValue) | ||||
|         { | ||||
|             if (thisValue != null && thisValue is byte[]) | ||||
|             { | ||||
|                 return string.Join("|",thisValue as byte[]); | ||||
|             } | ||||
|             if (thisValue != null) return thisValue.ToString().Trim(); | ||||
|             return ""; | ||||
|         } | ||||
|  | ||||
|         public static string ObjToString(this object thisValue, string errorValue) | ||||
|         { | ||||
|             if (thisValue != null) return thisValue.ToString().Trim(); | ||||
|             return errorValue; | ||||
|         } | ||||
|  | ||||
|         public static Decimal ObjToDecimal(this object thisValue) | ||||
|         { | ||||
|             Decimal reval = 0; | ||||
|             if (thisValue != null && thisValue != DBNull.Value && decimal.TryParse(thisValue.ToString(), out reval)) | ||||
|             { | ||||
|                 return reval; | ||||
|             } | ||||
|             return 0; | ||||
|         } | ||||
|  | ||||
|         public static Decimal ObjToDecimal(this object thisValue, decimal errorValue) | ||||
|         { | ||||
|             Decimal reval = 0; | ||||
|             if (thisValue != null && thisValue != DBNull.Value && decimal.TryParse(thisValue.ToString(), out reval)) | ||||
|             { | ||||
|                 return reval; | ||||
|             } | ||||
|             return errorValue; | ||||
|         } | ||||
|  | ||||
|         public static DateTime ObjToDate(this object thisValue) | ||||
|         { | ||||
|             if (thisValue is DateTime) | ||||
|             { | ||||
|                 return (DateTime)thisValue; | ||||
|             } | ||||
|             DateTime reval = DateTime.MinValue; | ||||
|             if (thisValue != null && thisValue != DBNull.Value && DateTime.TryParse(thisValue.ToString(), out reval)) | ||||
|             { | ||||
|                 reval = Convert.ToDateTime(thisValue); | ||||
|             } | ||||
|             return reval; | ||||
|         } | ||||
|  | ||||
|         public static DateTime ObjToDate(this object thisValue, DateTime errorValue) | ||||
|         { | ||||
|             if (thisValue is DateTime) | ||||
|             { | ||||
|                 return (DateTime)thisValue; | ||||
|             } | ||||
|             DateTime reval = DateTime.MinValue; | ||||
|             if (thisValue != null && thisValue != DBNull.Value && DateTime.TryParse(thisValue.ToString(), out reval)) | ||||
|             { | ||||
|                 return reval; | ||||
|             } | ||||
|             return errorValue; | ||||
|         } | ||||
|  | ||||
|         public static bool ObjToBool(this object thisValue) | ||||
|         { | ||||
|             bool reval = false; | ||||
|             if (thisValue != null && thisValue != DBNull.Value && bool.TryParse(thisValue.ToString(), out reval)) | ||||
|             { | ||||
|                 return reval; | ||||
|             } | ||||
|             return reval; | ||||
|         } | ||||
|  | ||||
|         internal static MemberExpression ToMemberExpression(Expression parentIdExpression) | ||||
|         { | ||||
|             if (parentIdExpression is UnaryExpression) | ||||
|             { | ||||
|                 return (parentIdExpression as UnaryExpression).Operand as MemberExpression; | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 return parentIdExpression as MemberExpression; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -497,6 +497,10 @@ namespace SqlSugar | ||||
|                     Check.Exception(SugarCompatible.IsFramework, "OceanBaseForOracle only support .net core"); | ||||
|                     InstanceFactory.CustomDllName = SugarCompatible.IsFramework ? "SqlSugar.OceanBaseForOracle" : "SqlSugar.OceanBaseForOracleCore"; | ||||
|                     break; | ||||
|                 case DbType.TDSQLForPGODBC: | ||||
|                     Check.Exception(SugarCompatible.IsFramework, "TDSQLForPGODBC only support .net core"); | ||||
|                     InstanceFactory.CustomDllName = SugarCompatible.IsFramework ? "SqlSugar.TDSQLForPGODBC" : "SqlSugar.TDSQLForPGODBC"; | ||||
|                     break; | ||||
|                 case DbType.GaussDB: | ||||
|                     config.DbType = DbType.PostgreSQL; | ||||
|                     if (this.CurrentConnectionConfig.MoreSettings == null) | ||||
|   | ||||
| @@ -33,6 +33,7 @@ namespace SqlSugar | ||||
|         Doris, | ||||
|         Xugu, | ||||
|         GoldenDB, | ||||
|         TDSQLForPGODBC, | ||||
|         Custom =900 | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -76,7 +76,11 @@ Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "DorisTest", "DorisTest\Dori | ||||
| EndProject | ||||
| Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "SqlSugar.XuguCore", "SqlSugar.XuguCore\SqlSugar.XuguCore.csproj", "{86C30210-A729-4F66-958D-173ADC512B2B}" | ||||
| EndProject | ||||
| Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2XuGuTest", "XuGuTest\2XuGuTest.csproj", "{4DA89736-24C7-4D20-B858-7DD304115E0A}" | ||||
| Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "2XuGuTest", "XuGuTest\2XuGuTest.csproj", "{4DA89736-24C7-4D20-B858-7DD304115E0A}" | ||||
| EndProject | ||||
| Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "SqlSugar.TDSQLForPGODBC", "SqlSugar.TDSQLForPGODBC\SqlSugar.TDSQLForPGODBC.csproj", "{B86EC97E-13F2-422B-8CA0-46181D40DEF2}" | ||||
| EndProject | ||||
| Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "TDSQLForPGOBDCTest", "TDSQLForPGOBDCTest\TDSQLForPGOBDCTest.csproj", "{307E0D47-28A5-4E1A-8350-5CDC6C790B32}" | ||||
| EndProject | ||||
| Global | ||||
| 	GlobalSection(SolutionConfigurationPlatforms) = preSolution | ||||
| @@ -496,6 +500,30 @@ Global | ||||
| 		{4DA89736-24C7-4D20-B858-7DD304115E0A}.Release|ARM32.Build.0 = Release|Any CPU | ||||
| 		{4DA89736-24C7-4D20-B858-7DD304115E0A}.Release|x86.ActiveCfg = Release|Any CPU | ||||
| 		{4DA89736-24C7-4D20-B858-7DD304115E0A}.Release|x86.Build.0 = Release|Any CPU | ||||
| 		{B86EC97E-13F2-422B-8CA0-46181D40DEF2}.Debug|Any CPU.ActiveCfg = Debug|Any CPU | ||||
| 		{B86EC97E-13F2-422B-8CA0-46181D40DEF2}.Debug|Any CPU.Build.0 = Debug|Any CPU | ||||
| 		{B86EC97E-13F2-422B-8CA0-46181D40DEF2}.Debug|ARM32.ActiveCfg = Debug|Any CPU | ||||
| 		{B86EC97E-13F2-422B-8CA0-46181D40DEF2}.Debug|ARM32.Build.0 = Debug|Any CPU | ||||
| 		{B86EC97E-13F2-422B-8CA0-46181D40DEF2}.Debug|x86.ActiveCfg = Debug|Any CPU | ||||
| 		{B86EC97E-13F2-422B-8CA0-46181D40DEF2}.Debug|x86.Build.0 = Debug|Any CPU | ||||
| 		{B86EC97E-13F2-422B-8CA0-46181D40DEF2}.Release|Any CPU.ActiveCfg = Release|Any CPU | ||||
| 		{B86EC97E-13F2-422B-8CA0-46181D40DEF2}.Release|Any CPU.Build.0 = Release|Any CPU | ||||
| 		{B86EC97E-13F2-422B-8CA0-46181D40DEF2}.Release|ARM32.ActiveCfg = Release|Any CPU | ||||
| 		{B86EC97E-13F2-422B-8CA0-46181D40DEF2}.Release|ARM32.Build.0 = Release|Any CPU | ||||
| 		{B86EC97E-13F2-422B-8CA0-46181D40DEF2}.Release|x86.ActiveCfg = Release|Any CPU | ||||
| 		{B86EC97E-13F2-422B-8CA0-46181D40DEF2}.Release|x86.Build.0 = Release|Any CPU | ||||
| 		{307E0D47-28A5-4E1A-8350-5CDC6C790B32}.Debug|Any CPU.ActiveCfg = Debug|Any CPU | ||||
| 		{307E0D47-28A5-4E1A-8350-5CDC6C790B32}.Debug|Any CPU.Build.0 = Debug|Any CPU | ||||
| 		{307E0D47-28A5-4E1A-8350-5CDC6C790B32}.Debug|ARM32.ActiveCfg = Debug|Any CPU | ||||
| 		{307E0D47-28A5-4E1A-8350-5CDC6C790B32}.Debug|ARM32.Build.0 = Debug|Any CPU | ||||
| 		{307E0D47-28A5-4E1A-8350-5CDC6C790B32}.Debug|x86.ActiveCfg = Debug|Any CPU | ||||
| 		{307E0D47-28A5-4E1A-8350-5CDC6C790B32}.Debug|x86.Build.0 = Debug|Any CPU | ||||
| 		{307E0D47-28A5-4E1A-8350-5CDC6C790B32}.Release|Any CPU.ActiveCfg = Release|Any CPU | ||||
| 		{307E0D47-28A5-4E1A-8350-5CDC6C790B32}.Release|Any CPU.Build.0 = Release|Any CPU | ||||
| 		{307E0D47-28A5-4E1A-8350-5CDC6C790B32}.Release|ARM32.ActiveCfg = Release|Any CPU | ||||
| 		{307E0D47-28A5-4E1A-8350-5CDC6C790B32}.Release|ARM32.Build.0 = Release|Any CPU | ||||
| 		{307E0D47-28A5-4E1A-8350-5CDC6C790B32}.Release|x86.ActiveCfg = Release|Any CPU | ||||
| 		{307E0D47-28A5-4E1A-8350-5CDC6C790B32}.Release|x86.Build.0 = Release|Any CPU | ||||
| 	EndGlobalSection | ||||
| 	GlobalSection(SolutionProperties) = preSolution | ||||
| 		HideSolutionNode = FALSE | ||||
| @@ -510,6 +538,7 @@ Global | ||||
| 		{A8FDDB0E-835A-4042-A955-66A2DB98207D} = {88992AAF-146B-4253-9AD7-493E8F415B57} | ||||
| 		{6DED25D0-660B-468A-AD61-7646345145F5} = {88992AAF-146B-4253-9AD7-493E8F415B57} | ||||
| 		{86C30210-A729-4F66-958D-173ADC512B2B} = {88992AAF-146B-4253-9AD7-493E8F415B57} | ||||
| 		{B86EC97E-13F2-422B-8CA0-46181D40DEF2} = {88992AAF-146B-4253-9AD7-493E8F415B57} | ||||
| 	EndGlobalSection | ||||
| 	GlobalSection(ExtensibilityGlobals) = postSolution | ||||
| 		SolutionGuid = {230A85B9-54F1-41B1-B1DA-80086581B2B4} | ||||
|   | ||||
							
								
								
									
										31
									
								
								Src/Asp.NetCore2/TDSQLForPGOBDCTest/Config.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								Src/Asp.NetCore2/TDSQLForPGOBDCTest/Config.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,31 @@ | ||||
| using System; | ||||
| using System.Collections.Generic; | ||||
| using System.Linq; | ||||
| using System.Text; | ||||
| using System.Threading.Tasks; | ||||
|  | ||||
| namespace TDSQLForPGOBDCTest | ||||
| { | ||||
|     /// <summary> | ||||
|     /// Setting up the database name does not require you to create the database | ||||
|     /// 设置好数据库名不需要你去手动建库 | ||||
|     /// </summary> | ||||
|     public class Config | ||||
|     { | ||||
|         /// <summary> | ||||
|         /// Account have permission to create database | ||||
|         /// 用有建库权限的数据库账号 | ||||
|         /// </summary> | ||||
|         public static string ConnectionString = "Driver={TDSQL PostgreSQL Unicode(x64)};Server=172.19.4.36;Port=11001;Database=xirdb;Uid=xir_app;Pwd=xpar;ConnSettings=set search_path to XIR_APP;"; | ||||
|         /// <summary> | ||||
|         /// Account have permission to create database | ||||
|         /// 用有建库权限的数据库账号 | ||||
|         /// </summary> | ||||
|         public static string ConnectionString2 = "Driver={GBase ODBC DRIVER (64-Bit)};Host=localhost;Service=19088;Server=gbase01;Database=testdb;Protocol=onsoctcp;Uid=gbasedbt;Pwd=GBase123;Db_locale=zh_CN.utf8;Client_locale=zh_CN.utf8"; | ||||
|         /// <summary> | ||||
|         /// Account have permission to create database | ||||
|         /// 用有建库权限的数据库账号 | ||||
|         /// </summary> | ||||
|         public static string ConnectionString3 = "Driver={GBase ODBC DRIVER (64-Bit)};Host=localhost;Service=19088;Server=gbase01;Database=testdb;Protocol=onsoctcp;Uid=gbasedbt;Pwd=GBase123;Db_locale=zh_CN.utf8;Client_locale=zh_CN.utf8"; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										51
									
								
								Src/Asp.NetCore2/TDSQLForPGOBDCTest/Program.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										51
									
								
								Src/Asp.NetCore2/TDSQLForPGOBDCTest/Program.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,51 @@ | ||||
| using SqlSugar; | ||||
| using SqlSugar.TDSQLForPGODBC; | ||||
|  | ||||
| namespace TDSQLForPGOBDCTest | ||||
| { | ||||
|     internal class Program | ||||
|     { | ||||
|         static void Main(string[] args) | ||||
|         { | ||||
|             Console.WriteLine(""); | ||||
|             Console.WriteLine("#### MasterSlave Start ####"); | ||||
|  | ||||
|             SqlSugarClient db = new SqlSugarClient(new ConnectionConfig() | ||||
|             { | ||||
|                 ConnectionString = Config.ConnectionString,//Master Connection | ||||
|                 DbType = DbType.TDSQLForPGODBC,//Oracle 模式用这个 ,如果是MySql 模式用DbType.MySql | ||||
|                 InitKeyType = InitKeyType.Attribute, | ||||
|                 IsAutoCloseConnection = true, | ||||
|                 MoreSettings = new ConnMoreSettings() | ||||
|                 { | ||||
|                     PgSqlIsAutoToLower = false,//增删查改支持驼峰表 | ||||
|                     PgSqlIsAutoToLowerCodeFirst = false, // 建表建驼峰表。5.1.3.30  | ||||
|                 } | ||||
|             }); | ||||
|             db.Aop.OnLogExecuted = (s, p) => | ||||
|             { | ||||
|                 Console.WriteLine(s); | ||||
|             }; | ||||
|             var list = db.Queryable<TSYS_USER>().ToList(); | ||||
|  | ||||
|             var page1 = db.Queryable<TSYS_USER>().ToOffsetPage(1, 30); | ||||
|  | ||||
|             db.Insertable<TSYS_USER>(new TSYS_USER | ||||
|             { | ||||
|                 U_ID = "DGSSqlsugar", | ||||
|                 U_NAME = "杜国舜SqlSugar适配", | ||||
|                 U_EMAIL = "dd2@" | ||||
|             }).ExecuteCommand(); | ||||
|  | ||||
|             db.Updateable<TSYS_USER>(new TSYS_USER | ||||
|             { | ||||
|                 U_ID = "DGSSqlsugar", | ||||
|                 U_NAME = "杜国舜SqlSugar适配,修改后", | ||||
|                 U_EMAIL = "dd2@" | ||||
|             }).ExecuteCommand(); | ||||
|  | ||||
|             db.Deleteable<TSYS_USER>().Where(m => m.U_ID == "DGSSqlsugar").ExecuteCommand(); | ||||
|  | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,15 @@ | ||||
| <Project Sdk="Microsoft.NET.Sdk"> | ||||
|  | ||||
|   <PropertyGroup> | ||||
|     <OutputType>Exe</OutputType> | ||||
|     <TargetFramework>net8.0</TargetFramework> | ||||
|     <ImplicitUsings>enable</ImplicitUsings> | ||||
|     <Nullable>enable</Nullable> | ||||
|   </PropertyGroup> | ||||
|  | ||||
|   <ItemGroup> | ||||
|     <ProjectReference Include="..\SqlSugar.TDSQLForPGODBC\SqlSugar.TDSQLForPGODBC.csproj" /> | ||||
|     <ProjectReference Include="..\SqlSugar\SqlSugar.csproj" /> | ||||
|   </ItemGroup> | ||||
|  | ||||
| </Project> | ||||
							
								
								
									
										58
									
								
								Src/Asp.NetCore2/TDSQLForPGOBDCTest/TSYS_USER.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										58
									
								
								Src/Asp.NetCore2/TDSQLForPGOBDCTest/TSYS_USER.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,58 @@ | ||||
| using SqlSugar; | ||||
| using System; | ||||
|  | ||||
| namespace TDSQLForPGOBDCTest | ||||
| { | ||||
|     ///<summary> | ||||
|     /// XIR用户表 | ||||
|     ///</summary> | ||||
|     [SugarTable("TSYS_USER")] | ||||
|     public partial class TSYS_USER | ||||
|     { | ||||
|         public TSYS_USER() | ||||
|         { | ||||
|  | ||||
|  | ||||
|         } | ||||
|         /// <summary> | ||||
|         /// Desc: | ||||
|         /// Default: | ||||
|         /// Nullable:False | ||||
|         /// </summary>             | ||||
|         [SugarColumn(IsNullable = false, IsPrimaryKey = true, Length = 30)] | ||||
|         public string U_ID { get; set; } | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Desc: | ||||
|         /// Default: | ||||
|         /// Nullable:True | ||||
|         /// </summary>            | ||||
|         [SugarColumn(IsNullable = true, Length = 50)] | ||||
|         public string U_NAME { get; set; } | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Desc: | ||||
|         /// Default: | ||||
|         /// Nullable:True | ||||
|         /// </summary>            | ||||
|         [SugarColumn(IsNullable = true, Length = 1)] | ||||
|         public string U_STATE { get; set; } | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Desc: | ||||
|         /// Default: | ||||
|         /// Nullable:True | ||||
|         /// </summary>            | ||||
|         [SugarColumn(IsNullable = true, Length = 2000)] | ||||
|         public string U_REMARK { get; set; } | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Desc: | ||||
|         /// Default: | ||||
|         /// Nullable:True | ||||
|         /// </summary>            | ||||
|         [SugarColumn(IsNullable = true, Length = 100)] | ||||
|         public string U_EMAIL { get; set; } | ||||
|  | ||||
|     } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user
	 guoshun.du
					guoshun.du