using System.Data;
using System.Data.SqlClient;
using System.Configuration;
using System.IO;
/*
* AUTHOR:ZHANGLEI
* CREATE DATE:2007.1.5
* 功能:BLL層,實現了數據庫操作的封裝
* 并且提供了足 " /> 亚洲欲色欲色XXXXX在线AV,中文字幕a有搜索网站,久久视频在线视频观品15

天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

自己常用到的自定義公共類(已測試通過)

using System;
using System.Data;
using System.Data.SqlClient;
using System.Configuration;
using System.IO;
/*
 * AUTHOR:ZHANGLEI
 * CREATE DATE:2007.1.5
 * 功能:BLL層,實現了數據庫操作的封裝
 * 并且提供了足夠的執行存儲過程的參數組合
 * DESCRIPTION:本類中用到了方法重載
 * ExecuteDataSet方法在本類中實現了四次重載
 * */
namespace job_17
{
 /// <summary>
 /// job17 的摘要說明。
 /// </summary>
 public class job17
 {
  private readonly string P_Con=ConfigurationSettings.AppSettings["P_Con"].ToString();
  public job17()
  {
   //
   // TODO: 在此處添加構造函數邏輯
   //
  }
  #region "執行任意參數組合的存儲過程"
  /// <summary>
  /// 命令準備操作,提供足夠多的參數組合
  /// 本類中一個比較重要的方法
  /// </summary>
  public void preparecommand(SqlConnection myconn,SqlCommand mycomm,SqlTransaction trans,CommandType cmdType,string cmdText,SqlParameter[] param) //注意里面的參數
  {
   if (myconn.State!=ConnectionState.Open)
   {
   myconn.Open();
   }
   mycomm.Connection=myconn;
   mycomm.CommandText=cmdText;
   if (trans!=null)
   {
   mycomm.Transaction=trans;
   }
   mycomm.CommandType=cmdType;
   if (param!=null)
   {
    foreach(SqlParameter parameter in param)
    {
    mycomm.Parameters.Add(parameter);
    }
   }
  }
  /// <summary>
  /// 第一個返回DataSet類型的ExecuteDataSet方法
  /// </summary>
  public DataSet ExecuteDataSet(SqlConnection myconn,CommandType cmdType,string cmdText,SqlParameter[] commandpara)
  {
  SqlCommand mycomm=new SqlCommand();
   preparecommand(myconn,mycomm,(SqlTransaction)null,cmdType,cmdText,commandpara);
   SqlDataAdapter adpt=new SqlDataAdapter(mycomm); //調用上方的preparecommand方法
   DataSet ds=new DataSet();
   adpt.Fill(ds);
   mycomm.Parameters.Clear();
   return ds;
  }
  /// <summary>
  /// 第二個返回DataSet類型的ExecuteDataSet方法
  /// 是在第一個方法的基礎上實現,實現了ExecuteDataSet方法的重載
  /// </summary>
  public DataSet ExecuteDataSet (string connstr,CommandType cmdType,string cmdText,SqlParameter[] cmdpara)//方法重載,在第一種的基礎上重載,以便提供足夠多的參數組合
  {
   using(SqlConnection myconn=new SqlConnection(connstr))
   {
   return ExecuteDataSet(myconn,cmdType,cmdText,cmdpara);
   }
  }
  /// <summary>
  /// 第三個返回DataSet類型的ExecuteDataSet方法 
  /// 提供使用存儲過程時不帶參數的組合
  /// </summary>
  public DataSet ExecuteDataSet(SqlConnection myconn,CommandType cmdType,string cmdText)
  {
  return ExecuteDataSet(myconn,cmdType,cmdText,(SqlParameter[])null);
  }
  /// <summary>
  /// 第四個返回DataSet類型的ExecuteDataSet方法
  /// 提供使用存儲過程時不帶參數的組合
  /// </summary>
  public DataSet ExecuteDataSet (string connstr,CommandType cmdType,string cmdText)
  {
  return ExecuteDataSet(connstr,cmdType,cmdText,(SqlParameter[])null);
  }
  #endregion
  #region "執行返回結果的sql語句"
  /// <summary>
  /// 返回結果的類型為DataTable
  /// </summary>
  public DataTable ExecuteDataTablesql(string sql)
  {
  SqlConnection myconn=new SqlConnection(P_Con);
   SqlDataAdapter adpt=new SqlDataAdapter(sql,myconn);
   DataSet ds=new DataSet();
   adpt.Fill(ds);
   return  ds.Tables[0];
  }
  /// <summary>
  /// 返回結果的類型為SqlDataReader
  /// </summary>
  public SqlDataReader ExecuteDataReadersql(string sql)
  {
  SqlConnection myconn=new SqlConnection(P_Con);
   SqlDataReader dr=null;
   SqlCommand mycomm=new SqlCommand(sql,myconn);
   try
   {
    myconn.Open();
    dr=mycomm.ExecuteReader();
   }
   catch
   {
//    StreamWriter sw=new StreamWriter(@"c:/err.txt",true,System.Text.Encoding.GetEncoding("GB2312"));
//    sw.WriteLine("============================出錯信息==========================");
//    sw.WriteLine("出錯時間:"+DateTime.Now.ToString()+"");
//    sw.WriteLine(ex.ToString());
//    sw.Close();
    throw;
   }
   return dr;
  }
  /// <summary>
  /// 返回結果的類型為DataSet 
  /// </summary>
  public DataSet ExecutesqlDS(string sql)
  {
    SqlConnection myconn=new SqlConnection(P_Con);
   SqlDataAdapter adpt=new SqlDataAdapter (sql,myconn);
   DataSet ds=new DataSet();
   adpt.Fill(ds);
   return ds;
  }
  #endregion
  #region "執行不返回結果的sql語句"
  /// <summary>
  /// 執行不返回結果的sql語句
  /// </summary>
  public void ExecuteNonsql(string sql)
  {
  SqlConnection myconn=new SqlConnection(P_Con);
   SqlCommand mycomm=new SqlCommand(sql,myconn);
   try
   {
    myconn.Open();
    mycomm.ExecuteNonQuery();
    myconn.Close();
   }
   catch(Exception e)
   {
//   StreamWriter sw=new StreamWriter(@"c:/err.txt",true,System.Text.Encoding.GetEncoding("GB2312"));
//    sw.WriteLine("============================出錯信息==========================");
//    sw.WriteLine("出錯時間:"+DateTime.Now.ToString()+"");
//    sw.WriteLine(e.ToString());
//    sw.Close();
    throw new Exception(e.Message,e);
   }
  }
  #endregion
  #region "啟用帶事務的sql語句如(insert,update)"
  /// <summary>
  /// 使用事務處理
  /// </summary>
  public void ExecuteTransql(string sql)
  {
  SqlConnection myconn=new SqlConnection(P_Con);
   SqlCommand mycomm=new SqlCommand(sql,myconn);
   SqlTransaction trans=null;
   try
   {
    myconn.Open();
    trans=myconn.BeginTransaction();
    mycomm.Transaction=trans;
    mycomm.ExecuteNonQuery();
    trans.Commit();
   }
   catch(Exception ex)
   {
   trans.Rollback();
    throw new Exception(ex.Message,ex);
   }
  }
  #endregion
 }
}

AspNet技術自己常用到的自定義公共類(已測試通過),轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 亚洲国产亚综合在线区尤物 | 让男人玩尿道的女人 | 亚洲男女羞羞无遮挡久久丫 | 国产在线观看网址你懂得 | 18禁国产精品久久久久久麻豆 | 少妇的肉体AA片免费 | 99re6热这里在线精品视频 | 欧美国产在线一区 | 亚洲国产在线精品国 | 中文字幕亚洲欧美日韩2o19 | 国产精品久人妻精品 | 一个人看的www视频动漫版 | 午夜理论片YY4399影院 | 强壮的公次次弄得我高潮韩国电影 | 大肚婆孕妇网 | 国产露脸150部国语对白 | 男男免费看 | 国产精品嫩草影视在线观看 | 99re热精品视频国产免费 | 草草色 | 亚洲免费va在线观看 | 国产精品禁18久久久夂久 | 久久精品国产首叶 | 999久久久无码国产精蜜柚 | 日韩人妻少妇一区二区三区 | 双性h浪荡受bl | 一级毛片全部免 | 久久亚洲伊人中字综合精品 | 果冻传媒完整免费网站在线观看 | 日产精品久久久久久久蜜殿 | 羞羞漫画免费漫画页面在线看漫画秋蝉 | 91在线一区二区 | 久久AV国产麻豆HD真实 | 护士日本xx厕所 | 亚洲欧美中文日韩v在线 | 无套内射CHINESEHD熟女 | 伊人网综合在线观看 | 久久er国产免费精品 | 麻豆传煤网站网址入口在线下载 | 无码AV毛片色欲欧洲美洲 | 朝鲜美女bbwbbw撒尿 |