DatabaseTableSqlServerService.cs 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Data;
  4. using System.Data.Common;
  5. using System.Linq;
  6. using System.Text;
  7. using System.Threading.Tasks;
  8. using YiSha.Data;
  9. using YiSha.Data.Repository;
  10. using YiSha.Enum;
  11. using YiSha.IService.SystemManage;
  12. using YiSha.Model.Result.SystemManage;
  13. using YiSha.Util;
  14. using YiSha.Util.Extension;
  15. using YiSha.Util.Model;
  16. namespace YiSha.Service.SystemManage
  17. {
  18. public partial class DatabaseTableSqlServerService : IDatabaseTableSqlServerService
  19. {
  20. private IRepositoryFactory _baseRepository;
  21. public DatabaseTableSqlServerService(IRepositoryFactory baseRepository)
  22. {
  23. _baseRepository = baseRepository;
  24. }
  25. #region 获取数据
  26. public async Task<List<TableInfo>> GetTableList(string tableName, DBConnectTypeEnum dbConnectType)
  27. {
  28. StringBuilder strSql = new StringBuilder();
  29. strSql.Append(@"SELECT id Id,name TableName FROM sysobjects WHERE xtype = 'u' order by name");
  30. IEnumerable<TableInfo> list = await _baseRepository.BaseRepository(dbConnectType).FindList<TableInfo>(strSql.ToString());
  31. if (!tableName.IsEmpty())
  32. {
  33. list = list.Where(p => p.TableName.Contains(tableName));
  34. }
  35. await SetTableDetail(dbConnectType, list);
  36. return list.ToList();
  37. }
  38. public async Task<List<TableInfo>> GetTablePageList(string tableName, DBConnectTypeEnum dbConnectType, Pagination pagination)
  39. {
  40. StringBuilder strSql = new StringBuilder();
  41. var parameter = new List<DbParameter>();
  42. strSql.Append(@"SELECT id Id,name TableName FROM sysobjects WHERE xtype = 'u'");
  43. if (!tableName.IsEmpty())
  44. {
  45. strSql.Append(" AND name like @TableName ");
  46. parameter.Add(DbParameterExtension.CreateDbParameter("@TableName", '%' + tableName + '%', dbConnectType));
  47. }
  48. IEnumerable<TableInfo> list = await _baseRepository.BaseRepository(dbConnectType).FindList<TableInfo>(strSql.ToString(), parameter.ToArray(), pagination);
  49. await SetTableDetail(dbConnectType, list);
  50. return list.ToList();
  51. }
  52. public async Task<List<TableFieldInfo>> GetTableFieldList(string tableName, DBConnectTypeEnum dbConnectType)
  53. {
  54. StringBuilder strSql = new StringBuilder();
  55. strSql.Append(@"SELECT
  56. TableColumn = rtrim(b.name),
  57. TableIdentity = CASE WHEN h.id IS NOT NULL THEN 'PK' ELSE '' END,
  58. Datatype = type_name(b.xusertype)+CASE WHEN b.colstat&1=1 THEN '[ID(' + CONVERT(varchar, ident_seed(a.name))+','+CONVERT(varchar,ident_incr(a.name))+')]' ELSE '' END,
  59. FieldLength = b.length,
  60. IsNullable = CASE b.isnullable WHEN 0 THEN 'N' ELSE 'Y' END,
  61. FieldDefault = ISNULL(e.text, ''),
  62. Remark = (SELECT ep.value FROM sys.columns sc LEFT JOIN sys.extended_properties ep ON ep.major_id = sc.object_id AND ep.minor_id = sc.column_id
  63. WHERE sc.object_id = a.id AND sc.name = b.name)
  64. FROM sysobjects a, syscolumns b
  65. LEFT OUTER JOIN syscomments e ON b.cdefault = e.id
  66. LEFT OUTER JOIN (Select g.id, g.colid FROM sysindexes f, sysindexkeys g Where (f.id=g.id)AND(f.indid=g.indid)AND(f.indid>0)AND(f.indid<255)AND(f.status&2048)<>0) h ON (b.id=h.id)AND(b.colid=h.colid)
  67. Where (a.id=b.id)AND(a.id=object_id(@TableName))
  68. ORDER BY b.colid");
  69. var parameter = new List<DbParameter>();
  70. parameter.Add(DbParameterExtension.CreateDbParameter("@TableName", tableName, dbConnectType));
  71. var list = await _baseRepository.BaseRepository(dbConnectType).FindList<TableFieldInfo>(strSql.ToString(), parameter.ToArray());
  72. return list.ToList();
  73. }
  74. #endregion
  75. #region 公有方法
  76. public async Task<bool> DatabaseBackup(string database, string backupPath, DBConnectTypeEnum dbConnectType)
  77. {
  78. string backupFile = string.Format("{0}\\{1}_{2}.bak", backupPath, database, DateTime.Now.ToString("yyyyMMddHHmmss"));
  79. string strSql = string.Format(" backup database [{0}] to disk = '{1}'", database, backupFile);
  80. var result = await _baseRepository.BaseRepository(dbConnectType).ExecuteBySql(strSql);
  81. return result > 0 ? true : false;
  82. }
  83. #endregion
  84. #region 私有方法
  85. /// <summary>
  86. /// 获取所有表的主键、主键名称、记录数
  87. /// </summary>
  88. /// <param name="dbConnectType"></param>
  89. /// <returns></returns>
  90. private async Task<List<TableInfo>> GetTableDetailList(DBConnectTypeEnum dbConnectType)
  91. {
  92. string strSql = @"SELECT (SELECT name FROM sysobjects as t WHERE xtype = 'U' and t.id = sc.id) TableName,
  93. sc.id Id,sc.name TableKey,sysobjects.name TableKeyName,sysindexes.rows TableCount
  94. FROM syscolumns sc ,sysobjects,sysindexes,sysindexkeys
  95. WHERE sysobjects.xtype = 'PK'
  96. AND sysobjects.parent_obj = sc.id
  97. AND sysindexes.id = sc.id
  98. AND sysobjects.name = sysindexes.name AND sysindexkeys.id = sc.id
  99. AND sysindexkeys.indid = sysindexes.indid
  100. AND sc.colid = sysindexkeys.colid;";
  101. IEnumerable<TableInfo> list = await _baseRepository.BaseRepository(dbConnectType).FindList<TableInfo>(strSql.ToString());
  102. return list.ToList();
  103. }
  104. /// <summary>
  105. /// 赋值表的主键、主键名称、记录数
  106. /// </summary>
  107. /// <param name="dbConnectType"></param>
  108. /// <param name="list"></param>
  109. private async Task SetTableDetail(DBConnectTypeEnum dbConnectType, IEnumerable<TableInfo> list)
  110. {
  111. List<TableInfo> detailList = await GetTableDetailList(dbConnectType);
  112. foreach (TableInfo table in list)
  113. {
  114. table.TableKey = string.Join(",", detailList.Where(p => p.Id == table.Id).Select(p => p.TableKey));
  115. var tableInfo = detailList.Where(p => p.TableName == table.TableName).FirstOrDefault();
  116. if (tableInfo != null)
  117. {
  118. table.TableKeyName = tableInfo.TableKeyName;
  119. table.TableCount = tableInfo.TableCount;
  120. table.Remark = tableInfo.Remark;
  121. }
  122. }
  123. }
  124. #endregion
  125. }
  126. }