zoukankan      html  css  js  c++  java
  • SQL Server 数据库访问通用类(更新)

      对SQL Server数据库的操作,最常见的有如下五种:

      1.非连接式查询,获取DataTable。

      2.连接式查询,获取DataReader。

      3.查询结果只有1行1列,获取单一数据。

      4.对数据库进行增、删、改操作,进行数据编辑。

      5.判断与数据库是否已连接。(更新)

      针对以上情况,分享的一个SQL Server数据库访问通用类。该通用类可用于ASP.NET和C/S系统中开发。

    1.非连接式查询,获取DataTable。

    利用SqlDataAdapter对象的Fill()返回DataTable的结果集。

    复制代码
    #region 执行一个查询,并返回结果集
    
        /// <summary>
        /// 执行一个查询,并返回结果集
        /// </summary>
        /// <param name="sql">要查询的SQL文本命令</param>
        /// <returns>查询结果集</returns>
        public DataTable ExecuteDataTable(string sql)
        {
            return ExecuteDataTable(sql, CommandType.Text, null);
        }
    
        /// <summary>
        /// 执行一个查询,并返回结果集
        /// </summary>
        /// <param name="sql">要查询的SQL文本命令</param>
        /// <param name="commandType">查询语句类型,存储过程或SQL文本命令</param>
        /// <returns>查询结果集</returns>
        public DataTable ExecuteDataTable(string sql, CommandType commandType)
        {
            return ExecuteDataTable(sql, commandType, null);
        }
    
        /// <summary>
        /// 执行一个查询,并返回结果集
        /// </summary>
        /// <param name="sql">要查询的SQL文本命令</param>
        /// <param name="commandType">查询语句类型,存储过程或SQL文本命令</param>
        /// <param name="parameters">T-SQL语句或存储过程的参数组</param>
        /// <returns>查询结果集</returns>
        public DataTable ExecuteDataTable(string sql, CommandType commandType, SqlParameter[] parameters)
        {
            //实例化DataTable,用于装载查询结果集
            DataTable data = new DataTable();
            using (SqlConnection connection = new SqlConnection(connectionString))
            {
                using (SqlCommand command = new SqlCommand(sql, connection))
                {
                    //指定CommandType
                    command.CommandType = commandType;
    
                    if (parameters != null)
                    {
                        foreach (SqlParameter parameter in parameters)
                        {
                            command.Parameters.Add(parameter);
                        }
                    }
                    //实例化SqlDataAdapter
                    SqlDataAdapter adapter = new SqlDataAdapter(command);
                    //填充DataTable
                    adapter.Fill(data);
                }
            }
            return data;
    
        }
    
        #endregion
    复制代码

    2.连接式查询,获取DataReader。

    利用SqlReader()返回DataReader对象实例。

    复制代码
    #region 返回一个DataReader对象实例
    
        /// <summary>
        /// 返回一个DataReader对象实例
        /// </summary>
        /// <param name="sql">要查询的SQL文本命令</param>
        /// <returns>DataReader对象实例</returns>
        public SqlDataReader ExecuteReader(string sql)
        {
            return ExecuteReader(sql, CommandType.Text, null);
        }
    
        /// <summary>
        /// 返回一个DataReader对象实例
        /// </summary>
        /// <param name="sql">要查询的SQL文本命令</param>
        /// <param name="commandType">要执行的查询语句的类型,存储过程或SQL文本命令</param>
        /// <returns>DataReader对象实例</returns>
        public SqlDataReader ExecuteReader(string sql, CommandType commandType)
        {
            return ExecuteReader(sql, commandType, null);
        }
    
        /// <summary>
        /// 返回一个DataReader对象实例
        /// </summary>
        /// <param name="sql">要查询的SQL文本命令</param>
        /// <param name="commandType">要执行的查询语句的类型,存储过程或SQL文本命令</param>
        /// <param name="parameters">T-SQL语句或存储过程的参数数组</param>
        /// <returns>DataReader对象实例</returns>
        public SqlDataReader ExecuteReader(string sql, CommandType commandType, SqlParameter[] parameters)
        {
            SqlConnection connection = new SqlConnection(connectionString);
            SqlCommand command = new SqlCommand(sql, connection);
    
            if (parameters != null)
            {
                foreach (SqlParameter parameter in parameters)
                {
                    command.Parameters.Add(parameter);
                }
            }
            connection.Open();
            //参数CommandBehavior.CloseConnection表示,关闭Reader对象的同时关闭Connection对象
            return command.ExecuteReader(CommandBehavior.CloseConnection);
        }
        #endregion
    复制代码

    3.查询结果只有1行1列,获取单一数据。

    利用SqlCommand的ExecuteScalar()。

    复制代码
    #region 执行查询结果,返回第一行的第一列
    
        /// <summary>
        /// 执行查询结果,返回第一行的第一列
        /// </summary>
        /// <param name="sql">要查询的SQL文本命令</param>
        /// <returns>返回第一行的第一列</returns>
        public object ExecuteScalar(string sql)
        {
            return ExecuteScalar(sql, CommandType.Text, null);
        }
    
        /// <summary>
        /// 执行查询结果,返回第一行的第一列
        /// </summary>
        /// <param name="sql">要查询的SQL文本命令</param>
        /// <param name="commandType">要执行的查询语句的类型,存储过程或SQL文本命令</param>
        /// <returns>返回第一行的第一列</returns>
        public object ExecuteScalar(string sql, CommandType commandType)
        {
            return ExecuteScalar(sql, commandType, null);
        }
    
        /// <summary>
        /// 执行查询结果,返回第一行的第一列
        /// </summary>
        /// <param name="sql">要查询的SQL文本命令</param>
        /// <param name="commandType">要执行的查询语句的类型,存储过程或SQL文本命令</param>
        /// <param name="parameters">T-SQL语句或存储过程的参数数组</param>
        /// <returns>返回第一行的第一列</returns>
        public object ExecuteScalar(string sql, CommandType commandType, SqlParameter[] parameters)
        {
            object result = null;
            using (SqlConnection connection = new SqlConnection(connectionString))
            {
                using (SqlCommand command = new SqlCommand(sql, connection))
                {
                    command.CommandType = commandType;
    
                    if (parameters != null)
                    {
                        foreach (SqlParameter parameter in parameters)
                        {
                            command.Parameters.Add(parameter);
                        }
                    }
    
                    connection.Open();
                    result = command.ExecuteScalar();
                }
    
            }
            return result;
        }
    
        #endregion
    复制代码

    4.对数据库进行增、删、改操作,进行数据编辑。

    利用ExecuteNonQuery()。

    复制代码
    #region 对数据库进行增删改操作
    
        /// <summary>
        /// 对数据库进行增删改操作
        /// </summary>
        /// <param name="sql">要执行的SQL文本命令</param>
        /// <returns>返回受影响的函数</returns>
        public int ExecuteNonQuery(string sql)
        {
            return ExecuteNonQuery(sql, CommandType.Text, null);
        }
    
        /// <summary>
        /// 对数据库进行增删改操作
        /// </summary>
        /// <param name="sql">要执行的SQL文本命令</param>
        /// <param name="commandType">要执行的查询语句的类型,存储过程或SQL文本命令</param>
        /// <returns>返回受影响的函数</returns>
        public int ExecuteNonQuery(string sql, CommandType commandType)
        {
            return ExecuteNonQuery(sql, commandType, null);
        }
    
        /// <summary>
        /// 对数据库进行增删改操作
        /// </summary>
        /// <param name="sql">要执行的SQL文本命令</param>
        /// <param name="commandType">要执行的查询语句的类型,存储过程或SQL文本命令</param>
        /// <param name="parameters">T-SQL语句或存储过程的参数数组</param>
        /// <returns>返回受影响的函数</returns>
        public int ExecuteNonQuery(string sql, CommandType commandType, SqlParameter[] parameters)
        {
            int count = 0;
            using (SqlConnection connection = new SqlConnection(connectionString))
            {
                using (SqlCommand command = new SqlCommand(sql, connection))
                {
                    command.CommandType = commandType;
    
                    if (parameters != null)
                    {
                        foreach (SqlParameter parameter in parameters)
                        {
                            command.Parameters.Add(parameter);
                        }
                    }
                    connection.Open();
                    count = command.ExecuteNonQuery();
    
                }
    
            }
            return count;
    
        }
    
    
        #endregion
    复制代码

    5.判断与数据库是否连接(更新)

    复制代码
    #region 判断数据库是否连接
    
        /// <summary>
        /// 判断数据库是否连接
        /// </summary>
        /// <returns>是否连接</returns>
        public bool IsConnected()
        {
            SqlConnection connection = new SqlConnection(connectionString);
            try
            {
                if (connection.State != ConnectionState.Open)
                {
                    connection.Open();
                }
                return true;
            }
            catch
            {
                return false;
            }
        }
    
        #endregion
    复制代码

    该类全部代码

    复制代码
    using System;
    using System.Data;
    using System.Data.SqlClient;
    using System.Configuration;
    
    /// <summary>
    /// SqlDbHelper:操作SQL Server数据库的通用类
    /// 作者:李宝亨
    /// 日期:2012-03-15
    /// Version:1.0
    /// </summary>
    public class SqlDbHelper
    {
        #region 字段
        /// <summary>
        /// 私有字段
        /// </summary>
        private string connectionString;
    
        #endregion
    
        #region 属性
    
        /// <summary>
        /// 公共属性 数据库连接字符串
        /// </summary>
        public string ConnectiongString
        {
            set { connectionString = value; }
        }
    
        #endregion
    
        #region 构造函数
    
        /// <summary>
        /// 构造函数
        /// </summary>
        public SqlDbHelper()
        {
            //修改connectionString为项目中的数据库连接字符串
            //connectionString="";
        }
    
        /// <summary>
        /// 构造函数
        /// </summary>
        /// <param name="strConnectionString">数据库连接字符串</param>
        public SqlDbHelper(string strConnectionString)
        {
            connectionString = strConnectionString;
        }
    
        #endregion
    
        #region 判断数据库是否连接
    
        /// <summary>
        /// 判断数据库是否连接
        /// </summary>
        /// <returns>是否连接</returns>
        public bool IsConnected()
        {
            SqlConnection connection = new SqlConnection(connectionString);
            try
            {
                if (connection.State != ConnectionState.Open)
                {
                    connection.Open();
                }
                return true;
            }
            catch
            {
                return false;
            }
        }
    
        #endregion
    
        #region 执行一个查询,并返回结果集
    
        /// <summary>
        /// 执行一个查询,并返回结果集
        /// </summary>
        /// <param name="sql">要查询的SQL文本命令</param>
        /// <returns>查询结果集</returns>
        public DataTable ExecuteDataTable(string sql)
        {
            return ExecuteDataTable(sql, CommandType.Text, null);
        }
    
        /// <summary>
        /// 执行一个查询,并返回结果集
        /// </summary>
        /// <param name="sql">要查询的SQL文本命令</param>
        /// <param name="commandType">查询语句类型,存储过程或SQL文本命令</param>
        /// <returns>查询结果集</returns>
        public DataTable ExecuteDataTable(string sql, CommandType commandType)
        {
            return ExecuteDataTable(sql, commandType, null);
        }
    
        /// <summary>
        /// 执行一个查询,并返回结果集
        /// </summary>
        /// <param name="sql">要查询的SQL文本命令</param>
        /// <param name="commandType">查询语句类型,存储过程或SQL文本命令</param>
        /// <param name="parameters">T-SQL语句或存储过程的参数组</param>
        /// <returns>查询结果集</returns>
        public DataTable ExecuteDataTable(string sql, CommandType commandType, SqlParameter[] parameters)
        {
            //实例化DataTable,用于装载查询结果集
            DataTable data = new DataTable();
            using (SqlConnection connection = new SqlConnection(connectionString))
            {
                using (SqlCommand command = new SqlCommand(sql, connection))
                {
                    //指定CommandType
                    command.CommandType = commandType;
    
                    if (parameters != null)
                    {
                        foreach (SqlParameter parameter in parameters)
                        {
                            command.Parameters.Add(parameter);
                        }
                    }
                    //实例化SqlDataAdapter
                    SqlDataAdapter adapter = new SqlDataAdapter(command);
                    //填充DataTable
                    adapter.Fill(data);
                }
            }
            return data;
    
        }
    
        #endregion
    
        #region 返回一个DataReader对象实例
    
        /// <summary>
        /// 返回一个DataReader对象实例
        /// </summary>
        /// <param name="sql">要查询的SQL文本命令</param>
        /// <returns>DataReader对象实例</returns>
        public SqlDataReader ExecuteReader(string sql)
        {
            return ExecuteReader(sql, CommandType.Text, null);
        }
    
        /// <summary>
        /// 返回一个DataReader对象实例
        /// </summary>
        /// <param name="sql">要查询的SQL文本命令</param>
        /// <param name="commandType">要执行的查询语句的类型,存储过程或SQL文本命令</param>
        /// <returns>DataReader对象实例</returns>
        public SqlDataReader ExecuteReader(string sql, CommandType commandType)
        {
            return ExecuteReader(sql, commandType, null);
        }
    
        /// <summary>
        /// 返回一个DataReader对象实例
        /// </summary>
        /// <param name="sql">要查询的SQL文本命令</param>
        /// <param name="commandType">要执行的查询语句的类型,存储过程或SQL文本命令</param>
        /// <param name="parameters">T-SQL语句或存储过程的参数数组</param>
        /// <returns>DataReader对象实例</returns>
        public SqlDataReader ExecuteReader(string sql, CommandType commandType, SqlParameter[] parameters)
        {
            SqlConnection connection = new SqlConnection(connectionString);
            SqlCommand command = new SqlCommand(sql, connection);
    
            if (parameters != null)
            {
                foreach (SqlParameter parameter in parameters)
                {
                    command.Parameters.Add(parameter);
                }
            }
            connection.Open();
            //参数CommandBehavior.CloseConnection表示,关闭Reader对象的同时关闭Connection对象
            return command.ExecuteReader(CommandBehavior.CloseConnection);
        }
        #endregion
    
        #region 执行查询结果,返回第一行的第一列
    
        /// <summary>
        /// 执行查询结果,返回第一行的第一列
        /// </summary>
        /// <param name="sql">要查询的SQL文本命令</param>
        /// <returns>返回第一行的第一列</returns>
        public object ExecuteScalar(string sql)
        {
            return ExecuteScalar(sql, CommandType.Text, null);
        }
    
        /// <summary>
        /// 执行查询结果,返回第一行的第一列
        /// </summary>
        /// <param name="sql">要查询的SQL文本命令</param>
        /// <param name="commandType">要执行的查询语句的类型,存储过程或SQL文本命令</param>
        /// <returns>返回第一行的第一列</returns>
        public object ExecuteScalar(string sql, CommandType commandType)
        {
            return ExecuteScalar(sql, commandType, null);
        }
    
        /// <summary>
        /// 执行查询结果,返回第一行的第一列
        /// </summary>
        /// <param name="sql">要查询的SQL文本命令</param>
        /// <param name="commandType">要执行的查询语句的类型,存储过程或SQL文本命令</param>
        /// <param name="parameters">T-SQL语句或存储过程的参数数组</param>
        /// <returns>返回第一行的第一列</returns>
        public object ExecuteScalar(string sql, CommandType commandType, SqlParameter[] parameters)
        {
            object result = null;
            using (SqlConnection connection = new SqlConnection(connectionString))
            {
                using (SqlCommand command = new SqlCommand(sql, connection))
                {
                    command.CommandType = commandType;
    
                    if (parameters != null)
                    {
                        foreach (SqlParameter parameter in parameters)
                        {
                            command.Parameters.Add(parameter);
                        }
                    }
    
                    connection.Open();
                    result = command.ExecuteScalar();
                }
    
            }
            return result;
        }
    
        #endregion
    
        #region 对数据库进行增删改操作
    
        /// <summary>
        /// 对数据库进行增删改操作
        /// </summary>
        /// <param name="sql">要执行的SQL文本命令</param>
        /// <returns>返回受影响的函数</returns>
        public int ExecuteNonQuery(string sql)
        {
            return ExecuteNonQuery(sql, CommandType.Text, null);
        }
    
        /// <summary>
        /// 对数据库进行增删改操作
        /// </summary>
        /// <param name="sql">要执行的SQL文本命令</param>
        /// <param name="commandType">要执行的查询语句的类型,存储过程或SQL文本命令</param>
        /// <returns>返回受影响的函数</returns>
        public int ExecuteNonQuery(string sql, CommandType commandType)
        {
            return ExecuteNonQuery(sql, commandType, null);
        }
    
        /// <summary>
        /// 对数据库进行增删改操作
        /// </summary>
        /// <param name="sql">要执行的SQL文本命令</param>
        /// <param name="commandType">要执行的查询语句的类型,存储过程或SQL文本命令</param>
        /// <param name="parameters">T-SQL语句或存储过程的参数数组</param>
        /// <returns>返回受影响的函数</returns>
        public int ExecuteNonQuery(string sql, CommandType commandType, SqlParameter[] parameters)
        {
            int count = 0;
            using (SqlConnection connection = new SqlConnection(connectionString))
            {
                using (SqlCommand command = new SqlCommand(sql, connection))
                {
                    command.CommandType = commandType;
    
                    if (parameters != null)
                    {
                        foreach (SqlParameter parameter in parameters)
                        {
                            command.Parameters.Add(parameter);
                        }
                    }
                    connection.Open();
                    count = command.ExecuteNonQuery();
    
                }
    
            }
            return count;
    
        }
    
    
        #endregion
    
    }
    复制代码

      点此下载SqlDbHelper.cs

  • 相关阅读:
    hdu1003 Max sum
    Java Programming Tutorial Programming Graphical User Interface (GUI)
    Java中int和String互相转换的多种方法
    Google搜索技巧总结
    HTML 教程延伸阅读:改变文本的外观和含义
    JAR 文件揭密
    sparql 学习,理解sparql
    sparql查询语言学习摘要
    经典算法总结
    杨辉三角
  • 原文地址:https://www.cnblogs.com/shixunle/p/3331094.html
Copyright © 2011-2022 走看看