一個方便的數據更新器-SqlDataUpdater

- 中國WEB開發者網絡 (http://www.webasp.net)
-- 技術教程 (http://www.webasp.net/article/)
--- 一個方便的數據更新器-SqlDataUpdater (http://www.webasp.net/article/18/17901.htm)
-- 作者:未知
-- 發佈日期: 2005-04-25
 

/// <summary>
 /// 文件名稱:SqlDataUpdater.cs
 /// 摘    要:SQL數據更新器,可方便對單數據表進行讀,寫,刪操作,構造函數按引用傳出結果集.
 ///    SqlDataUpdater du = new SqlDataUpdater(sqlHere,ref yourDataSet)
 ///    調用Update(ds)更新數據,自動事務處理,出錯信息存在 ErrorMessage.
 ///   
 /// 完成日期:2005-4-21
 /// 作    者:魏孫鼎
 /// 當前版本:1.0 
 /// </summary>
 public class SqlDataUpdater
 {
  private SqlConnection  cn;
  private SqlCommand   cmd;
  private SqlDataAdapter  da;
  private SqlTransaction  tran;
  private SqlCommandBuilder cmdBuilder;  
  private string    err;

  public string ErrorMessage
  {
   get
   {
    return err;
   }
  }
  
  /// <summary>
  /// 初始化數據更新器
  /// </summary>
  /// <param name="sql">用於返回schema的SQL</param>
  /// <param name="dataSet">按引用傳遞的數據集</param>
  public SqlDataUpdater(string sql,ref DataSet dataSet)
  {
   err = "";
   if (dataSet == null) dataSet = new DataSet();
   cn  = new SqlConnection(ZMarketData.DataSetting.ConnectionString);
   cmd = new SqlCommand(sql,cn);
   da  = new SqlDataAdapter(cmd);
   cmdBuilder = new SqlCommandBuilder(da);

   da.Fill(dataSet);   
  }

  public bool Update(DataSet ds)
  {
   bool success = false;
   cn.Open();
   tran = cn.BeginTransaction();
   cmd.Transaction = tran;
   try
   { 
    if(ds.GetChanges() != null)
    {
     da.Update(ds.GetChanges());
    }
    success = true;
    tran.Commit();
   }
   catch(Exception ex)
   {
    tran.Rollback();
    err = ex.Message;
    success = false;
   }
   return success;   
  }

  ~SqlDataUpdater()
  {
   da.Dispose();
   cmd.Dispose();
   cn.Dispose();
  }
 }

// 應用示例

DataSet ds = new DataSet();      
SqlDataUpdater du = new SqlDataUpdater("select * from Public_Feedback where 1=2",ref ds);

DataRow dr = ds.Tables[0].NewRow();

dr["CreateDate"] = DateTime.Now;
dr["FirstName"]  = Request["txtName"];
dr["CompanyName"] = Request["txtCompany"];
dr["Email"]   = Request["txtEmail"];

ds.Tables[0].Rows.Add(dr);
 if (du.Update(ds)) 
{
     //成功
}
else
{
     Response.Write(du.ErrorMessage);
}



webasp.net