c#数据库帮助类SqlHelper

来源:互联网 发布:太阳花 知乎 编辑:程序博客网 时间:2024/05/17 23:07
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;            }        }    }}

原创粉丝点击