C# 如何确定SQL Server 中数据表是否存在
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C# 如何确定SQL Server 中数据表是否存在相关的知识,希望对你有一定的参考价值。
SQL Server数据库的表名等信息属于架构集合的一部分,ADO.NET中的SqlConnection类包含的GetSchema 方法用于获取支持的架构集合列表,因此,要确定SQL Server 数据库中表是否存在是否存在,可通过SqlConnection.GetSchema("Tables")来获得,该方法返回一个DataTable,DataTable中包含table_catalog、table_schema、table_name、table_type等4列,table_name列即为数据表名。
示例代码如下:
using System; using System.Data; using System.Data.SqlClient; namespace ScratchLine.cn { public class Table { public Table() { } /// <summary> /// 判断数据库中名为tableName的表是否存在 /// </summary> /// <param name="tableName">要查询的表名</param> /// <param name="connectionString">数据库连接字符串</param> /// <returns></returns> public bool Exist(string tableName, string connectionString) { bool bExist = false; SqlConnection _Connection = new SqlConnection(connectionString); try { _Connection.Open(); using (DataTable dt = _Connection.GetSchema("Tables")) { foreach (DataRow dr in dt.Rows) { if (string.Equals(tableName, dr[2].ToString())) { bExist = true; break; } } } } catch (Exception ex) { throw ex; } finally { _Connection.Dispose(); } return bExist; } } }
要了解更多关于SQL Server架构集合的信息,可参看官方文档:https://msdn.microsoft.com/zh-cn/library/ms254969(v=vs.100).aspx
以上是关于C# 如何确定SQL Server 中数据表是否存在的主要内容,如果未能解决你的问题,请参考以下文章
如何确定 SQL Server 2012 中是不是存在序列?