转至繁体中文版     | 网站首页 | 图文教程 | 资源下载 | 站长博客 | 图片素材 | 武汉seo | 武汉网站优化 | 
最新公告:     敏韬网|教学资源学习资料永久免费分享站!  [mintao  2008年9月2日]        
您现在的位置: 学习笔记 >> 图文教程 >> 数据库 >> Sql Server >> 正文
一个方便的数据更新器-SqlDataUpdater         

一个方便的数据更新器-SqlDataUpdater

作者:闵涛 文章来源:闵涛的学习笔记 点击数:1090 更新时间:2007/11/14 13:06:56

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


[办公软件]在sybase中插入图片、PDF、文本文件  [办公软件]安装Sybase ASE
[办公软件]linux指令大全(完整篇)  [办公软件]Linux新手入门常用命令大全
[办公软件]在RedHat Linux 9里安装gaim0.80  [办公软件]浅谈Linux 下Java 1.5 汉字方块问题解决方法
[办公软件]Linux程序员必读:中文化与GB18030标准  [办公软件]linux指令大全
[办公软件]制作Linux启动盘的四种方法  [办公软件]Linux文件系统的反删除方法
教程录入:mintao    责任编辑:mintao 
  • 上一篇教程:

  • 下一篇教程:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
      注:本站部分文章源于互联网,版权归原作者所有!如有侵权,请原作者与本站联系,本站将立即删除! 本站文章除特别注明外均可转载,但需注明出处! [MinTao学以致用网]
      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)

    同类栏目
    · Sql Server  · MySql
    · Access  · ORACLE
    · SyBase  · 其他
    更多内容
    热门推荐 更多内容
  • 没有教程
  • 赞助链接
    更多内容
    闵涛博文 更多关于武汉SEO的内容
    500 - 内部服务器错误。

    500 - 内部服务器错误。

    您查找的资源存在问题,因而无法显示。

    | 设为首页 |加入收藏 | 联系站长 | 友情链接 | 版权申明 | 广告服务
    MinTao学以致用网

    Copyright @ 2007-2012 敏韬网(敏而好学,文韬武略--MinTao.Net)(学习笔记) Inc All Rights Reserved.
    闵涛 投放广告、内容合作请Q我! E_mail:admin@mintao.net(欢迎提供学习资源)

    站长:MinTao ICP备案号:鄂ICP备11006601号-18

    闵涛站盟:医药大全-武穴网A打造BCD……
    咸宁网络警察报警平台