c# 获取数据库中所有表名称的方法

上传人:飞*** 文档编号:39936279 上传时间:2018-05-21 格式:DOCX 页数:8 大小:25.26KB
返回 下载 相关 举报
c# 获取数据库中所有表名称的方法_第1页
第1页 / 共8页
c# 获取数据库中所有表名称的方法_第2页
第2页 / 共8页
c# 获取数据库中所有表名称的方法_第3页
第3页 / 共8页
c# 获取数据库中所有表名称的方法_第4页
第4页 / 共8页
c# 获取数据库中所有表名称的方法_第5页
第5页 / 共8页
点击查看更多>>
资源描述

《c# 获取数据库中所有表名称的方法》由会员分享,可在线阅读,更多相关《c# 获取数据库中所有表名称的方法(8页珍藏版)》请在金锄头文库上搜索。

1、c# 获取数据库中所有表名称的方法获取数据库中所有表名称的方法在很多情况下我们需要将指定的数据库中的所有表都列出来。在使在很多情况下我们需要将指定的数据库中的所有表都列出来。在使用用 c#进行软件开发时,我们有哪些方法可是实现这个目的呢?本人进行软件开发时,我们有哪些方法可是实现这个目的呢?本人对此进行概要的总结,有以下对此进行概要的总结,有以下 6 中方式可以实现这个目的。中方式可以实现这个目的。、sqldmo SQLDMO 是操作 SQLServer 的理想的方式,如果您的数据库是SQLServer 就可以考虑使用这种方式。在 C#中使用 SQLDMO 需要添加 SQLDMO 的引用,然后

2、在当前的文件中 using SQLDMO;即可以使用 SQLDMO。SQLDMO 的对象模型大家可以在 SQLServer 的帮助中获得。 复制代码 代码如下:private void GetTabels_DMO(string strServerName,string strUser,string strPWD,string strDatabase) SQLDMO.SQLServer Server = new SQLDMO.SQLServerClass(); /连接到服务器 Server.Connect(strServerName,strUser,strPWD); /对所有的数据库遍历,获得指

3、定数据库 for(int i=0;iServer.Databases.Count;i+) /判断当前数据库是否是指定数据库 if(Server.Databases.Item(i+1,“dbo“).Name =strDatabase) /获得指定数据库 SQLDMO._Database db= Server.Databases.Item(i+1,“dbo“); /获得指定数据库中的所有表 for(int j=0;jdb.Tables.Count;j+) MessageBox.Show(db.Tables.Item(j+1,“dbo“).Name); 、adox adox 是 ado Extens

4、ions for DDL and Security,是微软对 ADO 技术的扩展,使用它我们可以操作数据库的结构。它是一个 COM 组件,估计以后在 ADO.NET 中会增加 ADOX 的一些功能。如果大家需要 ADOX的一些资料,我可以提供。下面的一个例子就是使用 ADOX 来获得当前数据库的所有表。 复制代码 代码如下:private void GetTables_ADOX() /ADO 的数据库连接 ADODB.ConnectionClass cn=new ADODB.ConnectionClass(); string ConnectionString=“Provider=SQLOLED

5、B.1;Integrated Security=SSPI;Initial Catalog=Test;Data Source=HBXP“; cn.Open(ConnectionString,“sa“,“,0); /操作 ADOX 的 Catalog 对象 CatalogClass cat=new CatalogClass(); cat.ActiveConnection=cn; for(int i=0;icat.Tables.Count;i+) MessageBox.Show(cat.Tablesi.Name); 注意:在上面的代码中 cat.ActiveConnection 不能是 ADO.Ne

6、t 中的Connection,而应该是 ADO 的 Connection。 、 中的中的 oledbconnection 在 c#中我们首先会考虑使用 来解决问题,如果没有方法才会考虑使用 adox 或者 sqldmo 来解决这个问题。虽然 adox 和sqldmo 也能够解决这个问题,但是他们毕竟是 com 组件,在.net 中使用起来和在非.net 平台会有一些差异,不是很顺手。下面的示例就显示了在 中的 oledbconnection 的方法getoledbschematable 来获得数据库的架构。大家可以在 msdn 中看到这个方法的说明: public DataTable Ge

7、tOleDbSchemaTable( Guid schema, object restrictions); 参数 schema OleDbSchemaGuid 的值之一,它指定要返回的架构表。 restrictions 限制值的 Object 数组。这些值按照限制列的顺序来应用。即,第一个限制值应用于第一个限制列,第二个限制值应用于第二个限制列,依此类推。 返回值 包含请求的架构信息的 DataTable。 更多的信息大家可以查询 MSDN,下面将示例如何实现。 复制代码 代码如下:private void GetTables_ADONET() /处理 OleDbConnection stri

8、ng mailto:strConnectionString=%22Integrated Security=SSPI;Data Source=HBXP;Initial Catalog=Test;Provider=SQLOLEDB.1“; OleDbConnection cn=new OleDbConnection(strConnectionString); cn.Open(); /利用 OleDbConnection 的 GetOleDbSchemaTable 来获得数据库的结构 DataTable dt = cn.GetOleDbSchemaTable(OleDbSchemaGuid.Tabl

9、es,new object null, null, null, “TABLE“); foreach (DataRow dr in dt.Rows) MessageBox.Show(String)dr“TABLE_NAME“); 、信息架构视图、信息架构视图 信息架构视图是 sql-92 标准中定义的架构视图,这些视图独立于系统表。信息架构视图的最大优点是,即使我们对系统表进行了重要的修改,应用程序也可以正常地使用这些视图进行访问。下面的示例使用信息架构视图来工作。 复制代码 代码如下:private void GetTables_INFORMATION_SCHEMA() /打开连接 strin

10、g strConnectionString=System.Configuration.ConfigurationSettings.AppSettings“ConnectionString“; sqlcn=new SqlConnection(strConnectionString); sqlcn.Open(); /使用信息架构视图 SqlCommand sqlcmd=new SqlCommand(“SELECT TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_TYPE = BASE TABLE“,sqlcn); SqlDataReade

11、r dr=sqlcmd.ExecuteReader(); while(dr.Read() MessageBox.Show(dr.GetString(0); 、使用系统表、使用系统表 如果您的数据库系统是 sqlserver,就可以使用如下的方式来获得当前数据库的所有表: 复制代码 代码如下:private void GetTables_SystemTable() /打开连接 string strConnectionString=System.Configuration.ConfigurationSettings.AppSettings“ConnectionString“; sqlcn=new

12、SqlConnection(strConnectionString); sqlcn.Open(); /使用信息架构视图 SqlCommand sqlcmd=new SqlCommand(“SELECT OBJECT_NAME (id) FROM sysobjects WHERE xtype = U AND OBJECTPROPERTY (id, IsMSShipped) = 0“,sqlcn); SqlDataReader dr=sqlcmd.ExecuteReader(); while(dr.Read() MessageBox.Show(dr.GetString(0); 6、使用、使用 sq

13、lserver 的存储过程的存储过程“sp_tables” 下面是“盛国军”朋友提出的使用存储过程的方法的补充代码。 复制代码 代码如下:public void GetTables_StoredProcedure() /处理 OleDbConnection string mailto:strConnectionString=%22Integrated Security=SSPI;Data Source=HBXP;Initial Catalog=Test;Provider=SQLOLEDB.1“; OleDbConnection cn=new OleDbConnection(strConnectionString); cn.Open(); /执行存储过程 OleDbCommand cmd=new OleDbCommand(“sp_tables“,cn); cmd.CommandType=CommandType.StoredProcedure; OleDbDataReader dr=cmd.ExecuteReader(); while(dr.Read() MessageBox.Show(dr“TABLE_NAME“.ToString();

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 研究报告 > 综合/其它

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号