C#中 应用事物的SqlHelper

    using System;
using System.Data;
using System.Data.SqlClient;
using System.Configuration;
using System.ComponentModel;
using System.Collections.Generic;

namespace DLL
{
    public class SQLHelper
    {
        //连接数据源
        private static SqlConnection myConnection = null;
        private static readonly string connectionString = ConfigurationManager.ConnectionStrings["scm"].ConnectionString;


        //打开数据库连接.
        private static void Open()
        {
            if (myConnection == null)
            {
                myConnection = new SqlConnection(connectionString);
            }
            if (myConnection.State == ConnectionState.Closed)
            {
                try
                {
                    myConnection.Open();
                }
                catch (Exception ex)
                {
                    throw ex;
                }

            }
        }
        //关闭数据库连接
        public static void Close()
        {
            if (myConnection != null)
            {
                if (myConnection.State == ConnectionState.Open)
                {
                    myConnection.Close();
                }
            }
        }

        //释放资源
        public static void Dispose()
        {
            if (myConnection != null)
            {
                myConnection.Dispose();
                myConnection = null;
            }
        }
        //用于调用事物
        public static int RunProc(List<ProcList> list)
        {
            int re = 0;
            Open();
            SqlCommand cmd = new SqlCommand();
            cmd.Connection = myConnection;
            SqlTransaction trans = myConnection.BeginTransaction();
            try
            {
                cmd.Transaction = trans;

                for (int i = 0; i < list.Count; i++)
                {
                    cmd.CommandType = CommandType.StoredProcedure;
                    cmd.CommandText = list[i].procName;
                    cmd.Parameters.Clear();
                    if (list[i].prams != null)
                    {
                        foreach (SqlParameter parameter in list[i].prams)
                        {
                            if (parameter != null)
                            {
                                cmd.Parameters.Add(parameter);
                            }


                        }
                    }

                    re = cmd.ExecuteNonQuery();
                }
                trans.Commit();
                return re;
            }
            catch (Exception ex)
            {
                trans.Rollback();
                throw ex;
               
            }
            finally
            {
                Close();
            }
           
        }
        //用于增删改
        public static int RunProc(string procName, SqlParameter[] prams)
        {
            int count = 0;
            Open();
            SqlCommand cmd = new SqlCommand(procName, myConnection);
            cmd.CommandType = CommandType.StoredProcedure;
            SqlTransaction trans = myConnection.BeginTransaction();
            cmd.Transaction = trans;
            //判断是否为null
            if (prams != null)
            {
                foreach (SqlParameter item in prams)
                {
                    //判断其子项是否为null
                    if (item != null)
                    {
                        cmd.Parameters.Add(item);
                    }

                }
            }
            try
            {
                count = cmd.ExecuteNonQuery();
                trans.Commit();
                return count;
            }
            catch (Exception ex)
            {
                trans.Rollback();
                throw ex;
            }
            finally
            {
                Close();
            }
        }
        // 返回DataSet
        public static DataSet GetDataSet(string procName, SqlParameter[] prams)
        {
            DataSet ds = new DataSet();
            try
            {
                myConnection = new SqlConnection(connectionString);
                SqlCommand cmd = new SqlCommand(procName, myConnection);
                cmd.CommandType = CommandType.StoredProcedure;
                if (prams != null)//判断是否有参数
                {
                    foreach (SqlParameter item in prams)
                    {
                        if (item != null)
                        {
                            cmd.Parameters.Add(item);
                        }

                    }

                }
                SqlDataAdapter adapter = new SqlDataAdapter(cmd);
                adapter.Fill(ds);

            }
            catch (Exception ex)
            {
                throw ex;
            }
          
            return ds;
        }
        //用Sql脚本的
        public static DataSet RunSQL(string sql, SqlParameter[] prams)
        {
            Open();
            DataSet ds = new DataSet();
            try
            {
                SqlCommand cmd = new SqlCommand(sql, myConnection);
                if (prams != null)
                {
                    foreach (SqlParameter item in prams)
                    {
                        if (item != null)
                        {
                            cmd.Parameters.Add(item);
                        }

                    }
                }
                SqlDataAdapter da = new SqlDataAdapter(cmd);
                da.Fill(ds);

            }
            catch (Exception ex)
            {
                throw ex;
            }
          
            return ds;

        }
        //用Sql脚本2
        public static DataSet RunSQL(string sql)
        {
            Open();
            DataSet ds = new DataSet();
            try
            {
                SqlCommand cmd = new SqlCommand(sql, myConnection);
                SqlDataAdapter da = new SqlDataAdapter(cmd);
                da.Fill(ds);
            }
            catch (Exception ex)
            {
                throw ex;
            }
          
            return ds;

        }

        // 这个用于分页的调用,返回output总页数,和总条数
        public static DataSet GetDataSetAndOutput(string proName, SqlParameter[] para, out int pageCount, out int Counts)
        {
            DataSet ds = new DataSet();
            try
            {
                myConnection = new SqlConnection(connectionString);
                SqlDataAdapter da = new SqlDataAdapter(proName, myConnection);
                da.SelectCommand.CommandType = CommandType.StoredProcedure;
                if (para != null)
                {
                    foreach (SqlParameter parameter in para)
                    {
                        if (parameter != null)
                        {
                            da.SelectCommand.Parameters.Add(parameter);
                        }

                    }
                }
                da.SelectCommand.Parameters.Add("@pageCount", SqlDbType.Int).Direction = ParameterDirection.Output;
                da.SelectCommand.Parameters.Add("@Counts", SqlDbType.Int).Direction = ParameterDirection.Output;
                da.Fill(ds);
                pageCount = (int)da.SelectCommand.Parameters["@pageCount"].Value;
                Counts = (int)da.SelectCommand.Parameters["@Counts"].Value;
            }
            catch (Exception ex)
            {
                throw ex;
            }

            return ds;
        }

    }
}

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SqlHelper源码及使用实例下载 SqlHelper 类实现详细信息 SqlHelper 类用于通过一组静态方法来封装数据访问功能。该类不能被继承或实例化,因此将其声明为包含专用构造函数的不可继承类。 在 SqlHelper实现的每种方法都提供了一组一致的重载。这提供了一种很好的使用 SqlHelper 类来执行命令的模式,同时为开发人员选择访问数据的方式提供了必要的灵活性。每种方法的重载都支持不同的方法参数,因此开发人员可以确定传递连接、事务和参数信息的方式。在 SqlHelper实现的方法包括: ExecuteNonQuery。此方法用于执行不返回任何行或值的命令。这些命令通常用于执行数据库更新,但也可用于返回存储过程的输出参数。 ExecuteReader。此方法用于返回 SqlDataReader 对象,该对象包含由某一命令返回的结果集。 ExecuteDataset。此方法返回 DataSet 对象,该对象包含由某一命令返回的结果集。 ExecuteScalar。此方法返回一个值。该值始终是该命令返回的第一行的第一列。 ExecuteXmlReader。此方法返回 FOR XML 查询的 XML 片段。 除了这些公共方法外,SqlHelper 类还包含一些专用函数,用于管理参数和准备要执行的命令。不管客户端调用什么样的方法实现,所有命令都通过 SqlCommand 对象来执行。在 SqlCommand 对象能够被执行之前,所有参数都必须添加到 Parameters 集合,并且必须正确设置 Connection、CommandType、CommandText 和 Transaction 属性。SqlHelper的专用函数主要用于提供一种一致的方式,以便向 SQL Server 数据库发出命令,而不考虑客户端应用程序调用的重载方法实现。SqlHelper的专用实用程序函数包括: SqlHelper是非常方便的数据库操作函数,功能强大,使用起来非常简单,免去很多复杂的数据库操作的代码,在多层应用及面向对象开发都有很多应用 SqlHelper源码带有详细的说明,示例有原始的示例Sql语句 主要包括以下操作: 简单SQL语句(ExcuteSql) 带参数的简单SQL语句(ExcuteSQLParm) 简单存储过程 (ExcuteProc) 带参数的存储过程(ExcuteProcParm) 只返回一个字段 (ExcuteScalar) 返回数据集(ExcuteReader) 数据库有示例数据及存储过程updateTable\updateTableByParm,大家可以自行修改测试
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值