C# 如何确定SQL Server 中数据表是否存在

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C# 如何确定SQL Server 中数据表是否存在相关的知识,希望对你有一定的参考价值。

SQL Server数据库的表名等信息属于架构集合的一部分,ADO.NET中的SqlConnection类包含的GetSchema 方法用于获取支持的架构集合列表,因此,要确定SQL Server 数据库中表是否存在是否存在,可通过SqlConnection.GetSchema("Tables")来获得,该方法返回一个DataTableDataTable中包含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;
        }
    }
}
View Code

要了解更多关于SQL Server架构集合的信息,可参看官方文档:https://msdn.microsoft.com/zh-cn/library/ms254969(v=vs.100).aspx

以上是关于C# 如何确定SQL Server 中数据表是否存在的主要内容,如果未能解决你的问题,请参考以下文章

如何确定 SQL Server 2012 中是不是存在序列?

SQL Server 数据库更改侦听器 C#

如何使用 C# 可靠地确定安装了 SQL Server 2008 的哪些组件?

如何确定 SQL Server 2008 或更高版本

使用 C# 获取 SQL Server 列的数据类型

Sql Server 如何按每个月自动生成一张表,求大师指点一下下