当前位置:asp编程网>技术教程>Net教程>  正文

C# 数据库访问通用类 (ADO.NET)

2011-09-28 09:23:39   来源:博客园    作者:周公   浏览量:2501   收藏
using System;
using System.Collections.Generic;
using System.Text;
using System.Data;
using System.Data.SqlClient;
using System.Configuration;

namespace ADODoNETDemo
{
    /// 
    /// 针对SQL Server数据库操作的通用类
    /// 作者:周公
    /// 日期:2009-01-08
    /// Version:1.0
    /// 
    public class SqlDbHelper
    {
        private string connectionString;
        /// 
        /// 设置数据库连接字符串
        /// 
        public string ConnectionString
        {
            set { connectionString = value; }
        }
        /// 
        /// 构造函数
        /// 
        public SqlDbHelper()
            : this(ConfigurationManager.ConnectionStrings["Conn"].ConnectionString)
        {

        }
        /// 
        /// 构造函数
        /// 
        /// 数据库连接字符串
        public SqlDbHelper(string connectionString)
        {
            this.connectionString = connectionString;
        }
        /// 
        /// 执行一个查询,并返回结果集
        /// 
        /// 要执行的查询SQL文本命令
        /// 返回查询结果集
        public DataTable ExecuteDataTable(string sql)
        {
            return ExecuteDataTable(sql, CommandType.Text, null);
        }
        /// 
        /// 执行一个查询,并返回查询结果
        /// 
        /// 要执行的SQL语句
        /// 要执行的查询语句的类型,如存储过程或者SQL文本命令
        /// 返回查询结果集
        public DataTable ExecuteDataTable(string sql, CommandType commandType)
        {
            return ExecuteDataTable(sql, commandType, null);
        }
        /// 
        /// 执行一个查询,并返回查询结果
        /// 
        /// 要执行的SQL语句
        /// 要执行的查询语句的类型,如存储过程或者SQL文本命令
        /// Transact-SQL 语句或存储过程的参数数组
        /// 
        public DataTable ExecuteDataTable(string sql, CommandType commandType, SqlParameter[] parameters)
        {
            DataTable data = new DataTable();//实例化DataTable,用于装载查询结果集
            using (SqlConnection connection = new SqlConnection(connectionString))
            {
                using (SqlCommand command = new SqlCommand(sql, connection))
                {
                    command.CommandType = commandType;//设置command的CommandType为指定的CommandType
                    //如果同时传入了参数,则添加这些参数
                    if (parameters != null)
                    {
                        foreach (SqlParameter parameter in parameters)
                        {
                            command.Parameters.Add(parameter);
                        }
                    }
                    //通过包含查询SQL的SqlCommand实例来实例化SqlDataAdapter
                    SqlDataAdapter adapter = new SqlDataAdapter(command);

                    adapter.Fill(data);//填充DataTable
                }
            }
            return data;
        }
        /// 
        /// 
        /// 
        /// 要执行的查询SQL文本命令
        /// 
        public SqlDataReader ExecuteReader(string sql)
        {
            return ExecuteReader(sql, CommandType.Text, null);
        }
        /// 
        /// 
        /// 
        /// 要执行的SQL语句
        /// 要执行的查询语句的类型,如存储过程或者SQL文本命令
        /// 
        public SqlDataReader ExecuteReader(string sql, CommandType commandType)
        {
            return ExecuteReader(sql, commandType, null);
        }
        /// 
        /// 
        /// 
        /// 要执行的SQL语句
        /// 要执行的查询语句的类型,如存储过程或者SQL文本命令
        /// Transact-SQL 语句或存储过程的参数数组
        /// 
        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);
        }
        /// 
        /// 
        /// 
        /// 要执行的查询SQL文本命令
        /// 
        public Object ExecuteScalar(string sql)
        {
            return ExecuteScalar(sql, CommandType.Text, null);
        }
        /// 
        /// 
        /// 
        /// 要执行的SQL语句
        /// 要执行的查询语句的类型,如存储过程或者SQL文本命令
        /// 
        public Object ExecuteScalar(string sql, CommandType commandType)
        {
            return ExecuteScalar(sql, commandType, null);
        }
        /// 
        /// 
        /// 
        /// 要执行的SQL语句
        /// 要执行的查询语句的类型,如存储过程或者SQL文本命令
        /// Transact-SQL 语句或存储过程的参数数组
        /// 
        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;//设置command的CommandType为指定的CommandType
                    //如果同时传入了参数,则添加这些参数
                    if (parameters != null)
                    {
                        foreach (SqlParameter parameter in parameters)
                        {
                            command.Parameters.Add(parameter);
                        }
                    }
                    connection.Open();//打开数据库连接
                    result = command.ExecuteScalar();
                }
            }
            return result;//返回查询结果的第一行第一列,忽略其它行和列
        }
        /// 
        /// 对数据库执行增删改操作
        /// 
        /// 要执行的查询SQL文本命令
        /// 
        public int ExecuteNonQuery(string sql)
        {
            return ExecuteNonQuery(sql, CommandType.Text, null);
        }
        /// 
        /// 对数据库执行增删改操作
        /// 
        /// 要执行的SQL语句
        /// 要执行的查询语句的类型,如存储过程或者SQL文本命令
        /// 
        public int ExecuteNonQuery(string sql, CommandType commandType)
        {
            return ExecuteNonQuery(sql, commandType, null);
        }
        /// 
        /// 对数据库执行增删改操作
        /// 
        /// 要执行的SQL语句
        /// 要执行的查询语句的类型,如存储过程或者SQL文本命令
        /// Transact-SQL 语句或存储过程的参数数组
        /// 
        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;//设置command的CommandType为指定的CommandType
                    //如果同时传入了参数,则添加这些参数
                    if (parameters != null)
                    {
                        foreach (SqlParameter parameter in parameters)
                        {
                            command.Parameters.Add(parameter);
                        }
                    }
                    connection.Open();//打开数据库连接
                    count = command.ExecuteNonQuery();
                }
            }
            return count;//返回执行增删改操作之后,数据库中受影响的行数
        }
        /// 
        /// 返回当前连接的数据库中所有由用户创建的数据库
        /// 
        /// 
        public DataTable GetTables()
        {
            DataTable data = null;
            using (SqlConnection connection = new SqlConnection(connectionString))
            {
                connection.Open();//打开数据库连接
                data = connection.GetSchema("Tables");
            }
            return data;
        }

    }
}
(鼠标移到代码上去,在代码的顶部会出现四个图标,第一个是查看源代码,第二个是复制代码,第三个是打印代码,第四个是帮助)


关于我们-广告合作-联系我们-积分规则-网站地图

Copyright(C)2013-2017版权所属asp编程网