網站首頁 編程語言 正文
C# 獲取數據庫中所有表名、列名,實現代碼如下所示:
List<Dictionary<string, string>> GetColsName(Guid gtype,string tableName,string itemIndex= "COLUMN_NAME") { DataTable dsTablesData = DbDataHelper.GetCon().GetOleDbSchemaTable(gtype, new Object[] { null, null, tableName, null }); List<Dictionary<string, string>> ditCol = new List<Dictionary<string, string>>() ; for (int i = 0; i < dsTablesData.DefaultView.Table.Rows.Count; i++) { ditCol.Add(new Dictionary<string, string> { { i.ToString(), i.ToString() } }); } foreach (DataRow item in dsTablesData.DefaultView.Table.Rows) { int pos = Convert.ToInt32(item["ORDINAL_POSITION"]); int typeIndex = Convert.ToInt32(item["DATA_TYPE"]); ditCol[pos-1]= new Dictionary<string, string> { { item[itemIndex].ToString(), DBData.getInstance().GetColNameType(typeIndex) } }; } return ditCol; } List<string> GetTablesName(Guid gtype,string tableType ="TABLE", string strTableName =null , string itemIndex= "TABLE_NAME") { List<string> strNames = new List<string>(); DataTable dsTablesData = DbDataHelper.GetCon().GetOleDbSchemaTable(gtype, new Object[] { null, null, strTableName, tableType }); foreach (DataRow item in dsTablesData.DefaultView.Table.Rows) { strNames.Add(item[itemIndex].ToString()); } return strNames; }
調用
DBData.getInstance()._tableNames = GetTablesName(OleDbSchemaGuid.Tables); foreach (var tableName in DBData.getInstance()._tableNames) { List<Dictionary<string, string>> tmp = GetColsName(OleDbSchemaGuid.Columns, tableName); }
通過dataTable獲取
/// <summary> /// 根據datatable獲得列名 /// </summary> /// <param name="dt">表對象</param> /// <returns>返回結果的數據列數組</returns> public static List<string> GetColumnsByDataTable(DataTable dt) { List<string> list = new List<string>(); foreach (DataColumn item in dt.Columns) { list.Add(item.ColumnName); } return list; }
原文鏈接:https://blog.csdn.net/weixin_44291381/article/details/125082420
相關推薦
- 2022-05-06 利用python實現蝴蝶曲線_python
- 2023-02-07 Hive數據去重的兩種方式?(distinct和group?by)_數據庫其它
- 2023-05-12 Go異步任務解決方案之Asynq庫詳解_Golang
- 2022-03-18 Android?Activity生命周期調用的理解_Android
- 2022-12-27 Docker使用Calico網絡模式配置及問題處理方法_docker
- 2022-12-29 解決React報錯You?provided?a?`checked`?prop?to?a?form?f
- 2022-10-23 Redis的過期鍵刪除策略原理說明_Redis
- 2022-01-17 url傳參 中文出現亂碼問題 解決方案
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支