C# 一个SqlHelper例子

本文详细介绍了SQLHelper类的基本属性和常用方法,包括执行SQL、获取DataReader、查询DataTable和DataSet、获取单个值等操作,并提供了错误处理机制。通过实例演示了如何在实际项目中灵活运用该类进行数据库操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


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


/// <summary>
/// Summary description for SqlHelper
/// </summary>
public class SqlHelper : IDisposable
{
    #region 基本属性
    private string _lastError;


    public string LastError
    {
        get
        {
            return _lastError;
        }
        set
        {
            _lastError = value;
        }
    }




    public static string ConnectionString = ConfigurationSettings.AppSettings["DBConnectionString"];


    protected SqlConnection cnn;


    #endregion




    public SqlHelper()
    {
        this._lastError = string.Empty;
        try
        {
            cnn = new SqlConnection(ConnectionString);
            cnn.Open();
        }
        catch (Exception ex)
        {
            this._lastError = ex.Message;
            throw ex;
        }
    }






    ///执行sql
    public bool Execute(string sql)
    {
        try
        {
            this._lastError = string.Empty;
            using (SqlCommand cmd = new SqlCommand(sql.Trim(), cnn))
            {
                cmd.ExecuteNonQuery();
                return true;
            }
        }
        catch (Exception ex)
        {
            this._lastError = ex.Message;
            return false;
        }
    }




    ///执行,返回DataReader
    public SqlDataReader Reader(string sql)
    {
        try
        {
            this._lastError = string.Empty;
            using (SqlCommand cmd = new SqlCommand(sql.Trim(), cnn))
            {
                SqlDataReader dr = cmd.ExecuteReader();
                return dr;
            }
        }
        catch (Exception ex)
        {
            this._lastError = ex.Message;
            return null;
        }


    }


    ///执行sql,返回DataTable
    public DataTable Query(string sql)
    {
        this._lastError = string.Empty;


        DataTable dt = new DataTable();


        try
        {
            using (SqlDataAdapter da = new SqlDataAdapter(sql.Trim(), cnn))
            {
                da.Fill(dt);
                return dt;
            }
        }
        catch (Exception ex)
        {
            this._lastError = ex.Message;
            return null;
        }


    }




    ///执行sql,返回DataSet
    public DataSet Query(string sql, object inputNull)
    {
        this._lastError = string.Empty;


        DataSet ds = new DataSet();


        try
        {
            using (SqlDataAdapter da = new SqlDataAdapter(sql.Trim(), cnn))
            {
                da.Fill(ds);
                return ds;
            }
        }
        catch (Exception ex)
        {
            this._lastError = ex.Message;
            return null;
        }


    }




    ///执行sql,返回一串字符
    public string GetValue(string sql, int ColumnIndex)
    {
        try
        {
            this._lastError = string.Empty;


            using (SqlDataReader dr = this.Reader(sql))
            {
                if (dr.Read())
                {
                    return dr[ColumnIndex].ToString().Trim();
                }
                return string.Empty;
            }
        }
        catch (Exception ex)
        {
            this._lastError = ex.Message;
            return string.Empty;
        }
    }


    public string GetValue(string sql, string ColumnName)
    {
        try
        {
            this._lastError = string.Empty;


            using (SqlDataReader dr = this.Reader(sql))
            {
                if (dr.Read())
                {
                    return dr[ColumnName].ToString().Trim();
                }
                return string.Empty;
            }
        }
        catch (Exception ex)
        {
            this._lastError = ex.Message;
            return string.Empty;
        }
    }


    ~SqlHelper()
    {
        this.Dispose(false);
    }


    private bool disposed = false;


    public void Dispose()
    {
        Dispose(true);
        GC.SuppressFinalize(this);
    }


    private void Dispose(bool disposing)
    {
        if (!this.disposed && disposing)
        {
            try
            {
                cnn.Close();
                cnn.Dispose();
            }
            catch
            {
            }
        }
        disposed = true;
    }




}


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、付费专栏及课程。

余额充值