一个方便的数据更新器

发布时间: 2007-01-24 11:37    作者: 未知    来源: 未知    浏览:    评论

 

/// <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);
}


TAG

Smile Big Smile Surprise Stick out tongue Wink Sad Tongue Tied Indifferent Crying Embarrassed Cool Angry Angel Devil [8-|] [:#] [:-*] [:^)] [<:o)] [|-)] Yes Beer Left Hug Music Star Time Snail Pizza Automobile Umbrella Computer Storm [mo] [8o|] [^o)] [+o(] [*-)] [8-)] Coffee No Drinks [Z] Right Hug Cake Broken Heart Gift Wilted Flower Movie Dog Idea Sleep Email Travel Paradise
呢称:

加粗 斜体 下划线 链接 图片 代码 邮件地址 引用 列表

最多只能输入100个字符

Tags

SQL 数据库 asp.net C# XML 控件 .NET教程 程序 事件 数据 安全 代码 Server 客户端 验证 数据库专栏 接口 文件 Oracle DataSet 函数 DataGrid 问题 .net return C#语言 JavaScript 服务 IIS 对象 语句 windows 继承 时间 web.config 设计 开发 参数 变量 解决 字符 ADO.net 环境 VB.Net语言 web 异常 工具 服务器 计算 实例 OLEDB Application VB Word WebService insert asp net 安装 记录

精华推荐

更多

精品下载

更多