日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > C# >内容正文

C#

C#获取数据库表信息,列信息

發(fā)布時間:2025/4/14 C# 47 豆豆
生活随笔 收集整理的這篇文章主要介紹了 C#获取数据库表信息,列信息 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

獲取表的信息:

conn.Open();string[] restrictions = new string[4];restrictions[1] = "dbo"; DataTable table = conn.GetSchema("Tables", restrictions); conn.Close();

  

返回的table是表的所有信息,而不僅僅是名字,可以通過如下語句查看這些信息:

foreach (System.Data.DataRow row in table.Rows){foreach (System.Data.DataColumn col in table.Columns){Console.WriteLine("{0} = {1}", col.ColumnName, row[col]);}}

  

要獲取指定表的信息,關(guān)鍵是要設(shè)置數(shù)組restrictions的值。對于表而言,這個數(shù)組有如下的含義:

Restriction[0]表示表所在的Catalog

Restriction[1]表示表的所有者

Restriction[2]表示表的名字

Restriction[3]表示表的類型:

上面的例子就獲取了所有dbo擁有的表的信息。如果要獲取所有的用戶表,而非系統(tǒng)表,可用如下語句:

conn.Open();string[] restrictions = new string[4];restrictions[3] = “BASE TABLE"; DataTable table = conn.GetSchema("Tables", restrictions); conn.Close();

  

?

獲取列的信息:

conn.Open();string[] restrictions = new string[4];restrictions[1] = "dbo"; DataTable table = conn.GetSchema("Columns", restrictions); conn.Close();

  

與獲取表的代碼很類似,只是GetSchema的第一個參數(shù)不同。同樣,返回結(jié)果取決于restriction的值。此時,

Restriction[0]表示列所在的Catalog

Restriction[1]表示列的所有者

Restriction[2]表示列所在的表的名字

Restriction[3]表示列名

例如:

// restriction string arraystring[] res = new string[4];// dbo擁有的所有表的所有列的信息 res[1] = "dbo";DataTable t1 = conn.GetSchema("Columns", res);// 任意owner/schema所擁有的一個叫authors的表的列信息 res[2] = "authors";DataTable t2 = conn.GetSchema("Columns", res);//任意owner/schema所擁有的一個叫authors的表的列name的信息 res[2] = "authors"; res[3] = "name ";DataTable t3 = conn.GetSchema("Columns", res);//任意owner/schema任意表中的一個列名是name的列的信息。 res[3] = "name";DataTable t4 = conn.GetSchema("Columns", res);

?

?

?

獲取數(shù)據(jù)庫的其它信息都可以使用GetSchema,只是第一個參數(shù)不同。這個參數(shù)在不同的數(shù)據(jù)庫有差異:

1、在SQL Server中,可以獲取的架構(gòu)集合如下:

·?????Databases

·?????ForeignKeys

·?????Indexes

·?????IndexColumns

·?????Procedures

·?????ProcedureParameters

·?????Tables

·?????Columns

·?????Users

·?????Views

·?????ViewColumns

·?????UserDefinedTypes

2、在Oracle中,可以獲取的架構(gòu)集合如下:

·?????Columns

·?????Indexes

·?????IndexColumns

·?????Procedures

·?????Sequences

·?????Synonyms

·?????Tables

·?????Users

·?????Views

·?????Functions

·?????Packages

·?????PackageBodies

·?????Arguments

·?????UniqueKeys

·?????PrimaryKeys

·?????ForeignKeys

·?????ForeignKeyColumns

·?????ProcedureParameters

原文地址:http://www.csharpwin.com/csharpspace/11457r2196.shtml? ? ?轉(zhuǎn)載請注明出處

轉(zhuǎn)載于:https://www.cnblogs.com/YangFei-wow/p/3338987.html

總結(jié)

以上是生活随笔為你收集整理的C#获取数据库表信息,列信息的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。