.NET的DAO类

写了一个.NET的简易的DAO类

1.可以支持带或不带参数的SQL

2.可以返回XML的结果集或dataset的结果集


using System;
using System.Collections.Generic;
using System.Text;
using System.Configuration;
using System.Data.SqlClient;
using System.Data;
using System.Data.Common;

public class GeneralDAO
{
    static string conn = ConfigurationManager.ConnectionStrings
            ["ConnectionString"].ConnectionString;

    private SqlConnection Conn = null;



    public GeneralDAO()
    {

    }
    private void openConnection()
    {
        if (Conn == null) {
            Conn = new SqlConnection(conn);
            Conn.Open();
        }
        else if (Conn.State == System.Data.ConnectionState.Closed)
        {
            Conn.Open();
        }
        else if (Conn.State == System.Data.ConnectionState.Broken)
        {
            Conn.Close();
            Conn.Open();
        }
    }
    private void closeConnection()
    {
        if (Conn != null)
        {
            Conn.Close();
        }
      
    }

    public string doSearch(string sqls)
    {
        try
        {
            DataSet dataSet = new DataSet();
            openConnection();
            String result = "";
            SqlDataAdapter sqlDA = new SqlDataAdapter(sqls, Conn);
            sqlDA.Fill(dataSet, "Result");
            result = dataSet.GetXml();
            return result;

        }
        finally
        {
            closeConnection();
        }

    }

    public string doSearch(string sqls, IList<DbParameter> sqlparameters)
    {
        try
        {
            openConnection();
            String result="";
            using (SqlDataAdapter sqlDA = new SqlDataAdapter(sqls, Conn))
            {
                DataSet dataSet = new DataSet();
                if (sqlparameters != null)
                {

                    foreach (SqlParameter parameter in sqlparameters)
                    {
                        if ((parameter.Direction == ParameterDirection.InputOutput || parameter.Direction == ParameterDirection.Input) &&
                            (parameter.Value == null))
                        {
                            parameter.Value = DBNull.Value;
                        }
                        sqlDA.SelectCommand.Parameters.Add(parameter);
                    }
                }

                sqlDA.Fill(dataSet, "Result");
                sqlDA.SelectCommand.Parameters.Clear();
                result = dataSet.GetXml();
            }
            return result;
              
        }
        catch (SqlException ex)
        {
            throw new Exception(ex.Message);
        }
        finally
        {
            closeConnection();
        }

    }


    public DataSet doSearchByDataset(string sqls)
    {
        try
        {
            DataSet dataSet = new DataSet();
            openConnection();
            SqlDataAdapter sqlDA = new SqlDataAdapter(sqls, Conn);
            sqlDA.Fill(dataSet, "Result");
            return dataSet;

        }
        catch (SqlException ex)
        {
            throw new Exception(ex.Message);
        }
        finally
        {
            closeConnection();
        }

    }  


    public DataSet doSearchByDataset(string sqls, IList<DbParameter> sqlparameters)
    {
       
        try
        {
            openConnection();
            DataSet dataSet = new DataSet();
            using (SqlDataAdapter sqlDA = new SqlDataAdapter(sqls, Conn))
            {
                if (sqlparameters != null)
                {

                    foreach (SqlParameter parameter in sqlparameters)
                    {
                        if ((parameter.Direction == ParameterDirection.InputOutput || parameter.Direction == ParameterDirection.Input) &&
                            (parameter.Value == null))
                        {
                            parameter.Value = DBNull.Value;
                        }
                        sqlDA.SelectCommand.Parameters.Add(parameter);
                    }
                }

                sqlDA.Fill(dataSet, "Result");
                sqlDA.SelectCommand.Parameters.Clear();
                return dataSet;
                
            }
           
        }
       
        catch (SqlException ex)
        {
            throw new Exception(ex.Message);
        }
        finally
        {
            closeConnection();
        }

    }

    public bool doExec(string sqls)
    {
        bool result = false;
        openConnection();
        SqlTransaction trans = Conn.BeginTransaction();
        try
        {
            SqlCommand sqlcom = new SqlCommand();
            sqlcom.CommandText = sqls;
            sqlcom.Connection = Conn;
            sqlcom.Transaction = trans;
            sqlcom.ExecuteNonQuery();
            trans.Commit();
            result = true;
        }
        catch (SqlException ex)
        {
            result = false;
            throw new Exception(ex.Message);
        }
        finally
        {
            closeConnection();
        }
        return result;
    }

    public bool doExec(string sqls, IList<DbParameter> sqlparameters)
    {
        bool result = false;
        openConnection();
        SqlTransaction trans = Conn.BeginTransaction();
        try
        {
            using (SqlCommand sqlcom = new SqlCommand())
            {

                if (sqlparameters != null)
                {
                    foreach (SqlParameter parameter in sqlparameters)
                    {
                        if ((parameter.Direction == ParameterDirection.InputOutput || parameter.Direction == ParameterDirection.Input) &&
                            (parameter.Value == null))
                        {
                            parameter.Value = DBNull.Value;
                        }
                        sqlcom.Parameters.Add(parameter);
                    }
                }

                sqlcom.CommandText = sqls;
                sqlcom.Connection = Conn;
                sqlcom.Transaction = trans;
                sqlcom.ExecuteNonQuery();
                trans.Commit();
                result = true;

            }
        }
        catch (SqlException ex)
        {
            trans.Rollback();
            result = false;
            throw new Exception(ex.Message);
        }

        finally
        {
            closeConnection();
        }
        return result;
    }
}



使用:

string sqls = "insert into users(user_name) values(@username)";
        List<DbParameter> paramlist = new List<DbParameter>();
        SqlParameter p1 = new SqlParameter("@username", TextBox2.Text.Trim());
        paramlist.Add(p1);
        GeneralDAO dao = new GeneralDAO();
        dao.doExec(sqls, paramlist);


或:

        GeneralDAO dao = new GeneralDAO();
        dao.doSearch("select * from users");



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值