| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502 |
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Text;
- using System.Text.RegularExpressions;
- namespace SqlSugar
- {
- public class QuestDBDbMaintenance : DbMaintenanceProvider
- {
- #region DML
- protected override string GetDataBaseSql
- {
- get
- {
- return CreateDataBaseSql;
- }
- }
- protected override string GetColumnInfosByTableNameSql
- {
- get
- {
- string schema = GetSchema();
- string sql = @"SHOW COLUMNS FROM {0}";
- return sql;
- }
- }
- protected override string GetTableInfoListSql
- {
- get
- {
- var schema = GetSchema();
- return @"SHOW TABLES";
- }
- }
- protected override string GetViewInfoListSql
- {
- get
- {
- return "select * from (select 1 as id) t where id=0";
- }
- }
- #endregion
- #region DDL
- protected override string CreateDataBaseSql
- {
- get
- {
- return "select * from (select 1 as id) t where id=0";
- }
- }
- protected override string AddPrimaryKeySql
- {
- get
- {
- return "";
- }
- }
- protected override string AddColumnToTableSql
- {
- get
- {
- return "ALTER TABLE {0} ADD COLUMN {1} {2}";
- }
- }
- protected override string AlterColumnToTableSql
- {
- get
- {
- throw new NotSupportedException("Alter Column ");
- }
- }
- protected override string BackupDataBaseSql
- {
- get
- {
- return "BACKUP DATABASE";
- }
- }
- protected override string CreateTableSql
- {
- get
- {
- return "CREATE TABLE {0}(\r\n{1})";
- }
- }
- 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 " ";
- }
- }
- protected override string RenameColumnSql
- {
- get
- {
- return "ALTER TABLE {0} RENAME COLUMN {1} TO {2}";
- }
- }
- protected override string AddColumnRemarkSql => " ";
- protected override string DeleteColumnRemarkSql => " ";
- protected override string IsAnyColumnRemarkSql { get { throw new NotSupportedException(); } }
- protected override string AddTableRemarkSql => " ";
- protected override string DeleteTableRemarkSql => " ";
- protected override string IsAnyTableRemarkSql { get { throw new NotSupportedException(); } }
- protected override string RenameTableSql => "alter table 表名 {0} 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) from (SELECT to_regclass('{0}') as c ) t where t.c is not null";
- }
- }
- protected override string IsAnyProcedureSql => throw new NotImplementedException();
- #endregion
- #region Check
- protected override string CheckSystemTablePermissionsSql
- {
- get
- {
- return "select 1 ";
- }
- }
- #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 void AddIndex(EntityInfo entityInfo)
- {
- if (entityInfo.Indexs != null)
- {
- foreach (var item in entityInfo.Indexs)
- {
- CreateIndex(entityInfo.DbTableName, item.IndexFields.Select(it => it.Key).ToArray(),item.IsUnique);
- }
- }
- }
- public override bool CreateIndex(string tableName, string[] columnNames, bool isUnique = false)
- {
- if (isUnique)
- {
- this.Context.Ado.ExecuteCommand($"ALTER TABLE {tableName} DEDUP ENABLE UPSERT KEYS({string.Join(",",columnNames)})");
- return true;
- }
- var columnInfos = this.Context.Ado.SqlQuery<QuestDbColumn>("SHOW COLUMNS FROM '" + tableName + "'");
- foreach (var columnInfo in columnInfos)
- {
- if (columnNames.Any(z => z.EqualCase(columnInfo.Column)))
- {
- if (!columnInfo.Type.EqualCase("SYMBOL"))
- {
- Check.ExceptionEasy(true, "Only the SYMBOL type can be indexed", $"字段{columnInfo.Column} 不是SYMBOL并且实体是string才能添加索引,CodeFirst需要指定类型: SYMBOL");
- }
- if (columnInfo.Indexed == false)
- {
- var indexSql = $"ALTER TABLE '{tableName}' ALTER COLUMN {columnInfo.Column} ADD INDEX ";
- this.Context.Ado.ExecuteCommand(indexSql);
- }
- }
- }
- return true;
- }
- public override bool CreateIndex(string tableName, string[] columnNames, string IndexName, bool isUnique = false)
- {
- if(isUnique)
- throw new Exception("no support unique index");
- return CreateIndex(tableName, columnNames, isUnique);
- }
- public override bool CreateUniqueIndex(string tableName, string[] columnNames)
- {
- throw new Exception("no support unique index");
- }
- public override bool IsAnyIndex(string indexName)
- {
- return false;
- }
- public override List<DbTableInfo> GetTableInfoList(bool isCache = true)
- {
- var dt = this.Context.Ado.GetDataTable(GetTableInfoListSql);
- List<DbTableInfo> result = new List<DbTableInfo>();
- foreach (System.Data.DataRow dr in dt.Rows)
- {
- DbTableInfo di = new DbTableInfo();
- di.Name = dr[0] + "";
- if (!di.Name.Contains("sys.") && !di.Name.IsIn("telemetry", "telemetry_config") )
- {
- result.Add(di);
- }
- }
- return result;
- }
- public override bool AddDefaultValue(string tableName, string columnName, string defaultValue)
- {
- return base.AddDefaultValue(this.SqlBuilder.GetTranslationTableName(tableName), this.SqlBuilder.GetTranslationTableName(columnName), defaultValue);
- }
- public override bool AddColumnRemark(string columnName, string tableName, string description)
- {
- //tableName = this.SqlBuilder.GetTranslationTableName(tableName);
- //string sql = string.Format(this.AddColumnRemarkSql, columnName, 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);
- return true;
- }
- public override bool UpdateColumn(string tableName, DbColumnInfo columnInfo)
- {
- //no support
- return false;
- }
- public override bool AddPrimaryKey(string tableName, string columnName)
- {
- 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., 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)))
- {
- newDb.Ado.ExecuteCommand(string.Format(CreateDataBaseSql, this.SqlBuilder.SqlTranslationLeft+databaseName+this.SqlBuilder.SqlTranslationRight, databaseDirectory));
- }
- 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)
- {
- var splitSql = "";
- if (tableName.Contains("_TIMESTAMP("))
- {
- splitSql = Regex.Match(tableName,@"_TIMESTAMP\(.+$").Value;
- tableName = tableName.Replace(splitSql, "");
- }
- if (columns.HasValue())
- {
- foreach (var item in columns)
- {
- if (item.DbColumnName.Equals("GUID", StringComparison.CurrentCultureIgnoreCase) && item.Length == 0)
- {
- 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()))));
- }
- sql = sql.Replace("$PrimaryKey", primaryKeyInfo);
- this.Context.Ado.ExecuteCommand(sql+ splitSql.TrimStart('_')+ " BYPASS WAL");
- return true;
- }
- 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 = "";
- //if (item.DecimalDigits > 0&&item.Length>0 && dataType == "numeric")
- //{
- // dataSize = $"({item.Length},{item.DecimalDigits})";
- //}
- string nullType = "";
- string primaryKey = null;
- string addItem = string.Format(this.CreateTableColumn, this.SqlBuilder.GetTranslationColumnName(columnName.ToLower()), dataType, dataSize, nullType, primaryKey, "");
- //if (item.IsIdentity)
- //{
- // 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), 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 sql = String.Format(GetColumnInfosByTableNameSql,tableName);
- List<DbColumnInfo> result = new List<DbColumnInfo>();
- var dt = this.Context.Ado.GetDataTable(sql);
- foreach (System.Data.DataRow column in dt.Rows)
- {
- DbColumnInfo dbColumnInfo = new DbColumnInfo();
- dbColumnInfo.DbColumnName = column[0]+"";
- dbColumnInfo.DataType = column[1]+"";
- result.Add(dbColumnInfo);
- }
- return result;
- }
- #endregion
- #region Helper
- 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;
- }
- #endregion
- #region HelperClass
- internal class QuestDbColumn
- {
- public string Column { get; set; }
- public string Type { get; set; }
- public bool Indexed { get; set; }
- }
- #endregion
- }
- }
|