C#处理Access中事务的方法
作者:baggio7095586 发布时间:2021-07-01 13:43:39
标签:C#,Access,事务
本文实例讲述了C#处理Access中事务的方法。分享给大家供大家参考。具体如下:
Access不能像SQL server一样直接执行多条语句,但是把多条语句绑成事务还是可以一起执行的. 所谓事务,就是把多件事情当做一件事情来处理。也就是大家同在一条船上! 由一个事务来完成多个表的同步操作,要么都执行成功,要么都不成功.下面举个例子,用C#实现Access数据库事务的处理方法: 向一个表提交数据,同时更新另一个表中的数据
using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.Data.OleDb;
public partial class _Default : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
}
protected void Button1_Click(object sender, EventArgs e)
{
string id = "";
string strCon = System.Configuration.ConfigurationManager.AppSettings["ConnectStr"].ToString();
OleDbConnection con = new OleDbConnection(strCon);
OleDbDataAdapter adp = new OleDbDataAdapter();
OleDbDataAdapter adp1 = new OleDbDataAdapter();
try
{
con.Open();
OleDbTransaction tra = con.BeginTransaction(); //创建事务,开始执行事务
adp = new OleDbDataAdapter("select * from 序号表", con);
adp.SelectCommand.Transaction = tra;
adp1=new OleDbDataAdapter("select * from 节目表", con);
adp1.SelectCommand.Transaction = tra;
OleDbCommandBuilder thisBuilder = new OleDbCommandBuilder(adp);
OleDbCommandBuilder thisBuilder1 = new OleDbCommandBuilder(adp1);
DataSet ds = new DataSet();
adp.Fill(ds,"aa");//添加数据集
id = ds.Tables["aa"].Rows[0][1].ToString();
Int64 s = 0;
s = Convert.ToInt64(id) + 1;
id = s.ToString("0000000#");
ds.Tables["aa"].Rows[0][1] = id;
adp.Update(ds,"aa");//执行修改一个表的事务
adp1.Fill(ds,"bb");
DataRow dr=ds.Tables["bb"].NewRow();
dr["ProID"]=id;
dr["ProName"]="ProName";
dr["ProTime"]="2";
dr["ProIsFinish"]="3";
dr["ProBgColor"]="4";
dr["ProBgPic"]="5";
dr["ProStyle"]="6";
dr["MissionName"]="7";
dr["ProDescription"]="8";
ds.Tables["bb"].Rows.Add(dr);
adp1.Update(ds,"bb");
tra.Commit();//关闭事务
}
catch (Exception ex)
{
}
finally
{
con.Close();
}
}
注:Access的事务不支持自动锁定(经试验已经证实),因此Access最好用于本机的程序,b/s中做好不要用,除非你不用事务处理~~!
希望本文所述对大家的C#程序设计有所帮助。
0
投稿
猜你喜欢
- 新公司工程是用Maven管理的,技术上使用了JPA,但是我导入工程到MyEclipse时,applicationContext.xml中提示
- 本文实例讲述了C#实现Excel导入sqlite的方法,是非常实用的技巧。分享给大家供大家参考。具体方法如下:首先需要引用system.da
- 本文实例为大家分享了java获取当前时间年月日的具体代码,供大家参考,具体内容如下import java.text.ParseExcepti
- 思维导图一、为什么要学习 DialogFragment你还在用 Dialog 吗?你还在经常烦恼于屏幕翻转的时候,Dialog 的各种奇葩情
- 自定义转换器实现参数去空格1.自定义转换器类实现Converter<S, T>类,重写convert()方法,直接上代码。/**
- Spring的七个核心模块,供大家参考,具体内容如下1、Spring core:核心容器核心容器提供spring框架的基本功能。Spring
- 使用@Provider注意事项(要点)1.在Mapper接口和@InsertProvider方法类中,不要使用重载,也就是说,不要使用方法名
- 现在Java的大部分项目都是基于Maven, 在Maven项目中使用Selenium2. 非常简单。 首先你需要配置好
- 1. Spring 是什么我们通常所说的 Spring 指的是 Spring Framework(Spring 框架),它是一个开源框架,有
- 本文实例讲述了Java基于命令模式实现邮局发信功能。分享给大家供大家参考,具体如下:一. 模式定义命令模式,将来自客户端的请求封建为一个对象
- 测试例:PageElement pe = new PageElement();pe.LoadDataFromJsonString("
- Intent在不同的组件中传递对象数据的应用非常普遍,大家都知道在intent传递对象的方法有两种:1、实现Serializable接口、2
- 本文实例为大家分享了Viewpager2实现登录注册引导页面的具体代码,供大家参考,具体内容如下介绍屏幕滑动是两个完整屏幕之间的切换,在设置
- 我们肯定遇到过打开别人的项目时一直处于Building‘XXX'Gradle project info的情况。本文通过两种方法带领大
- 网上很多资料在描述Java内存模型的时候,都会介绍有一个主存,然后每个工作线程有自己的工作内存。数据在主存中会有一份,在工作内存中也有一份。
- Java8新特性系列我们已经介绍了Stream、Lambda表达式、DateTime日期时间处理,最后以“NullPointerExcept
- 1、synchronized的作用为了避免临界区的竞态条件发生,有多种手段可以达到目的。阻塞式的解决方案:synchronized,Lock
- 升级到grails 2.3.2之后,运行时报如下的异常:Exception in thread "main"Error
- 字符串和列表学完,自己试着写了一个非常简单的Python名片管理系统。新萌尝试,大佬们不要喷。修改名片的功能我偷了个懒,因为我不知道怎么通过
- 安装 Tomcat 之前请一定先安装 Java ,然后才能安装 Tomcat 。安装 Java 、环境变量 path 的设置以及 cmd 小