您的位置:首页 > 博客中心 > 数据库 >

C#获取Access数据库中的所有表名和列名

时间:2022-03-14 16:50

//C#获取Access数据库中的所有表名和列名
    string ConnectionString = "Provider=Microsoft.Jet.OLEDB.4.0;" + @"Data Source=E:\report20100819\report20100819.mdb";
    OleDbConnection Conn = new OleDbConnection(ConnectionString);
    Conn.Open();

    DataTable shemaTable = Conn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, new object[] { null, null, null, "TABLE" });
    foreach (DataRow dr in shemaTable.Rows)
    {
     Console.WriteLine(dr["TABLE_NAME"]);
     DataTable columnTable = Conn.GetOleDbSchemaTable(OleDbSchemaGuid.Columns, new object[] { null, null, dr["TABLE_NAME"].ToString(), null });
     foreach (DataRow dr2 in columnTable.Rows)
     {
         Console.WriteLine(dr2["COLUMN_NAME"]);
     }
    }
    Conn.Close();

 

解释:
    “Conn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, new object[] { null, null, null, "TABLE" });”返回数据库中所有的数据表清单,返回值为DataTable。
    “Conn.GetOleDbSchemaTable(OleDbSchemaGuid.Columns, new object[] { null, null, dr["TABLE_NAME"].ToString(), null });”返回指定数据表中所有的数据列清单,返回值为DataTable。

本类排行

今日推荐

热门手游