zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    求一个整数的划分
    HDU 1028 Ignatius and the Princess III
    HDU1215
    博弈论(2)
    阶乘的位数
    母函数详解
    SpragueGrundy FunctionSG函数博弈论(3)
    图的基本操作邻接表类型
    HDU 1536 SG函数应用
    顺序栈的实现
  • 原文地址:https://www.cnblogs.com/two/p/5223650.html
Copyright © 2011-2022 走看看