C#数据库帮助类SqlHelper

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Data.OleDb;
using System.Data;
using System.Configuration;
using System.Data.Sql;
using System.Data.SqlClient;
namespace DAL
{
    public class SqlHelper
    {
        public static string connstring = ConfigurationManager.ConnectionStrings["zzconstr"].ConnectionString;
        //public static string connstring = "Data Source=ZZ-PC;Initial Catalog=IPTVDB;User ID=sa;Password=sa";
        /// <summary>
        /// 执行非查询,返回受影响行数,异常返回-1;
        /// </summary>
        /// <param name="sql"></param>
        /// <param name="type"></param>
        /// <param name="pars"></param>
        /// <returns></returns>
        public static bool ExceNonQuery(string sql, CommandType type, IDataParameter[] pars)
        {
            
            SqlConnection con = new SqlConnection(connstring);
            SqlCommand com = new SqlCommand(sql, con);
            
            if (pars != null && pars.Length > 0)
            {
                foreach (SqlParameter pp in pars)//把参数集全部加进去
                    com.Parameters.Add(pp);
            }
            try
            {
                con.Open();
                int t = com.ExecuteNonQuery();
                if (t > 0)
                {
                    return true;
                }
                else
                    return false;
            }
            catch (Exception e) { return false; }
            finally
            {
                com.Parameters.Clear();
                com.Dispose();
                con.Close();
            }
        }
        /// <summary>
        /// 执行sql语句的查询,返回查询的数量。异常返回-1.
        /// </summary>
        /// <param name="sql"></param>
        /// <param name="type"></param>
        /// <param name="pars"></param>
        /// <returns></returns>
        public static int ExceQuery(string sql, CommandType type, IDataParameter[] pars)
        {
            SqlConnection con = new SqlConnection(connstring);
            SqlCommand com = new SqlCommand(sql, con);
            com.CommandType = type;
            if (pars != null && pars.Length > 0)
            {
                foreach (SqlParameter pp in pars)//把参数集全部加进去
                    com.Parameters.Add(pp);
            }
            try
            {
                con.Open();
                if (com.ExecuteScalar() != null)//查询结果为空时返回0
                {
                    int t = (int)com.ExecuteScalar();

                    return t;
                }
                else
                    return -1;
            }
            catch (Exception e) { return -1; }
            finally
            {
                com.Parameters.Clear();
                com.Dispose();
                con.Close();
            }
        }
        /// <summary>
        /// 执行查询,返回一个数据集
        /// </summary>
        /// <param name="sql"></param>
        /// <param name="pars"></param>
        /// <returns></returns>
        public static DataSet ExcueReturnDataset(string sql, IDataParameter[] pars)
        {
            SqlConnection con = new SqlConnection(connstring);
            DataSet set = new DataSet();
            SqlCommand com = new SqlCommand(sql, con);
            if (pars != null && pars.Length > 0)
            {
                foreach (SqlParameter pp in pars)//把参数集全部加进去
                    com.Parameters.Add(pp);
            }
            
            SqlDataAdapter adpter = new SqlDataAdapter(com);
            
            try
            {
                set.Clear();
                adpter.Fill(set);
                return set;
            }
            catch (Exception ex) { return null; }
            finally {
                com.Parameters.Clear();
                com.Dispose();
                con.Close(); 
            }

        }
        public static DataSet ExcueReturnDataset(string sql,CommandType type,IDataParameter[] pars)
        {
            SqlConnection con = new SqlConnection(connstring);
            DataSet set = new DataSet();
            SqlCommand com = new SqlCommand(sql, con);
            com.CommandType = type;
            if (pars != null && pars.Length > 0)
            {
                foreach (SqlParameter pp in pars)//把参数集全部加进去
                    com.Parameters.Add(pp);
            }

            SqlDataAdapter adpter = new SqlDataAdapter(com);

            try
            {
                set.Clear();
                adpter.Fill(set);
                return set;
            }
            catch (Exception ex) { return null; }
            finally
            {
                com.Parameters.Clear();
                com.Dispose();
                con.Close();
            }

        }
        public static IDataReader ExcueReturnDataReader(string sql, IDataParameter[] pars)
        {
            SqlConnection con = new SqlConnection(connstring);
            SqlCommand com = new SqlCommand(sql, con);
            
            SqlDataReader reader;
            if (pars != null && pars.Length > 0)
            {
                foreach (SqlParameter pp in pars)//把参数集全部加进去
                    com.Parameters.Add(pp);
            }
            try
            {
                con.Open();
                reader = com.ExecuteReader(CommandBehavior.CloseConnection);
                return reader;
            }
            catch (Exception ex)
            { 
                
                return null; 
            }
            finally {
                com.Parameters.Clear();
                com.Dispose();
                //con.Close();
            }

        }
        /// <summary>
        /// 执行存储过程,返回影响的行数        
        /// </summary>
        /// <param name="storedProcName">存储过程名</param>
        /// <param name="parameters">存储过程参数</param>
        /// <param name="rowsAffected">影响的行数</param>
        /// <returns></returns>
        public static int RunProcedure(string storedProcName, IDataParameter[] parameters, out int rowsAffected)
        {
            using (SqlConnection connection = new SqlConnection(connstring))
            {
                int result;
                connection.Open();
                SqlCommand command = new SqlCommand(storedProcName, connection);
                command.CommandType = CommandType.StoredProcedure;
                if (parameters!= null && parameters.Length > 0)
                {
                    foreach (SqlParameter pp in parameters)//把参数集全部加进去
                        command.Parameters.Add(pp);
                }
                command.Parameters.Add("@return","").Direction = ParameterDirection.ReturnValue;
                rowsAffected = command.ExecuteNonQuery();
                result = (int)command.Parameters["@return"].Value;
                connection.Close();
                return result;
            }
        }
        /// <summary>
        /// 执行存储过程
        /// </summary>
        /// <param name="storedProcName">存储过程名</param>
        /// <param name="parameters">存储过程参数</param>
        /// <param name="tableName">DataSet结果中的表名</param>
        /// <returns>DataSet</returns>
        public static DataSet RunProcedure(string storedProcName, IDataParameter[] parameters, string tableName)
        {
            using (SqlConnection connection = new SqlConnection(connstring))
            {
                DataSet dataSet = new DataSet();
                SqlCommand com = new SqlCommand(storedProcName, connection);
                com.CommandType =CommandType.StoredProcedure;
                if (parameters != null && parameters.Length > 0)
                {
                    foreach (SqlParameter pp in parameters)//把参数集全部加进去
                        com.Parameters.Add(pp);
                }

                SqlDataAdapter adpter = new SqlDataAdapter(com);
                adpter.Fill(dataSet, tableName);
                return dataSet;
            }
        }
        /// <summary>
        /// 执行查询语句,返回DataSet
        /// </summary>
        /// <param name="SQLString">查询语句</param>
        /// <returns>DataSet</returns>
        public DataSet Query(string SQLString)
        {
            using (SqlConnection connection = new SqlConnection(connstring))
            {
                DataSet ds = new DataSet();
                try
                {
                    connection.Open();
                    SqlDataAdapter command = new SqlDataAdapter(SQLString, connection);
                    command.Fill(ds, "ds");
                }
                catch (System.Data.SqlClient.SqlException ex)
                {
                    throw new Exception(ex.Message);
                }
                return ds;
            }
        }
    }
}

http://www.open-open.com/lib/view/open1391348424801.html

posted @ 2014-04-17 23:49  如.若  阅读(455)  评论(0编辑  收藏  举报