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

数据

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

时间: 2024-12-23 07:25:14

一个方便的数据更新器-SqlDataUpdater的相关文章

一个java类方法提取器

很少需要直接使用反射工具:之所以在语言中提供它们,仅仅是为了支持其他Java特性,比如对象序列化(第10章介绍).Java Beans以及RMI(本章后面介绍).但是,我们许多时候仍然需要动态提取与一个类有关的资料.其中特别有用的工具便是一个类方法提取器.正如前面指出的那样,若检视类定义源码或者联机文档,只能看到在那个类定义中被定义或覆盖的方法,基础类那里还有大量资料拿不到.幸运的是,"反射"做到了这一点,可用它写一个简单的工具,令其自动展示整个接口.下面便是具体的程序:   //:

android-Android 自己写的一个全局事件管理器,感觉还有点儿问题,提上代码,希望大神们修改修改!!!

问题描述 Android 自己写的一个全局事件管理器,感觉还有点儿问题,提上代码,希望大神们修改修改!!! import java.util.ArrayList; import java.util.Collections; import java.util.LinkedList; import java.util.List; import java.util.Map; import java.util.concurrent.ConcurrentHashMap; import android.os

单片机 倒计时-谁能帮我设计一个89c51的一个八人抢答器的汇编程序,万分感谢!!!

问题描述 谁能帮我设计一个89c51的一个八人抢答器的汇编程序,万分感谢!!! 1.数码管前一位显示抢答,后两位显示倒计时60s 2,p1.2为开始按钮 解决方案 //以前做过的,需要按你的要求改一改,望采纳. #include #include #include #define uchar unsigned char #define uint unsigned int #define D8279 XBYTE[0x5EFF] //8279 数据口地址 #define C8279 XBYTE[0x

js 轮播-一个js轮播器,可以用用但是性能差

问题描述 一个js轮播器,可以用用但是性能差 html------------------------ <!doctype html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <link rel="stylesheet" href="style/main.cs

用mfc编写一个windows文件资源管理器

问题描述 用mfc编写一个windows文件资源管理器 需要创建几个类,以及怎样封装哪些函数及数据 解决方案 http://download.csdn.net/download/mingyuan0826/2716853 解决方案二: VS2008SP1的有个Samples文件下的Explorer能实现类似的效果. ...Samples1033AllVCLanguageSamplesC++MFCVisual C++ 2008 Feature PackExplorer 解决方案三: 还有请问左右视图

使用Qt做一个简易音乐播放器[Phonon浅谈--续]

2010-2-13 使用Qt做一个简易音乐播放器[Phonon浅谈--续]   在第一篇Phonon浅谈中提及到了Phonon这个多媒体框架的一些基本知识,于是想着结合这些基本知识来实践一番,做一个简单的音乐播放器.   [步骤一] 新建一个Qt Gui工程,在建立过程中需要包含Phonon模块,之后生成文件如下图: Qt Gui工程会生成一个ui文件,在这里是mainwindow.ui.双击mainwindow.ui进行一番简单的布局,如下图: 关于这个ui界面,中央位置是一个QListWid

flash-问: 10 我想做一个winform的播放器来播放斗鱼的直播,求大神指点。

问题描述 问: 10 我想做一个winform的播放器来播放斗鱼的直播,求大神指点. 目前没有思路,希望大神出来指点一二.我试过了很多种,利用flash 的插件也无法实现. 解决方案 webbrowser里面加载http://www.douyutv.com/ 解决方案二: 想做一个推荐系统,求志同道合者...

使用70行Python代码实现一个递归下降解析器的教程_python

 第一步:标记化 处理表达式的第一步就是将其转化为包含一个个独立符号的列表.这一步很简单,且不是本文的重点,因此在此处我省略了很多. 首先,我定义了一些标记(数字不在此中,它们是默认的标记)和一个标记类型:   token_map = {'+':'ADD', '-':'ADD', '*':'MUL', '/':'MUL', '(':'LPAR', ')':'RPAR'} Token = namedtuple('Token', ['name', 'value']) 下面就是我用来标记 `expr`

如何创建一个视屏播放器?

问题描述 我是一个学生,我知道像"皮皮狗"."优酷"."迅雷"."暴风影音"."pps"."快播"等等视屏播放器,可是我不知道怎么样才能自己制作一个类似的播放器,请大家给我点意见,我目前了解一点c#语言,也懂得一点asp.net和sqlserver数据库,请高手指点迷津,我很想学,请高手指点一下,我会非常感谢. 解决方案 解决方案二:照着这个例子自己动手做就可以了,地址: