SQL Server数据库的表名等信息属于架构集合的一部分,
ADO.NET中的SqlConnection类包含的 GetSchema 方法用于获取支持的架构集合列表,
因此,要确定SQL Server 数据库中表是否存在是否存在,
可通过SqlConnection.GetSchema(“Tables”)来获得,
该方法返回一个DataTable,
DataTable中包含table_catalog、table_schema、table_name、table_type等4列,table_name列即为数据表名。
示例代码如下
/// <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架构集合的信息,可参看官方文档