Oracle 的事务操作,有时候想在批量操作数据集合的时候,执行一次失败,即为了避免数据异常,将所有的操作回滚。
.NET给我们提供了良好的事务操作,Oracle端也有事务操作,可以灵活使用,此处介绍.NET的事务。 1、.NET事务操作Oracle存储过程
public string insert_input_attach_info_moto(DataTable dt, string ass_code, string cust_model, string ship_date, string cust_name, string ship_city,
string ship_country, string po_cstname, string po_no, string chd_code, ref decimal batch_id)
{
string rtnMsg = ""; //存储过程返回信息
OracleConnection conn = (OracleConnection)DataBase.Provider.GetConnection(); //创建并开启 OracleConnection
conn.Open();
//启动事务
OracleTransaction tran = conn.BeginTransaction();
try
{
OracleCommand cmd = conn.CreateCommand();
cmd.Transaction = tran; //绑定事务
cmd.CommandType = CommandType.StoredProcedure;
cmd.CommandText = "pkg_name.procedure_name"; //具体的方法 cmd.Parameters.AddWithValue("p_ass_code", ass_code); //参数占位符
cmd.Parameters.AddWithValue("p_cust_model", cust_model);
cmd.Parameters.AddWithValue("p_ship_date", ship_date);
cmd.Parameters.AddWithValue("p_cust_name", cust_name);
cmd.Parameters.AddWithValue("p_ship_city", ship_city); cmd.Parameters.AddWithValue("p_ship_country", ship_country);
cmd.Parameters.AddWithValue("p_po_cstname", po_cstname);
cmd.Parameters.AddWithValue("p_po_no", po_no);
cmd.Parameters.AddWithValue("p_chd_code", chd_code);
cmd.Parameters.AddWithValue("p_batch_id", batch_id); cmd.Parameters.Add("p_msg", OracleType.VarChar, ); cmd.Parameters[].Direction = ParameterDirection.Output; foreach(DataRow row in dt.Rows)
{
cmd.Parameters[].Value = row["SN"]; //此处是改变的参数,根据实际情况赋值
cmd.ExecuteNonQuery();
rtnMsg = cmd.Parameters[].Value.ToString(); //每次执行的返回值,若出现异常,可以对此值判断,并确认是否回滚操作
} tran.Commit();
}
catch (Exception ex)
{
tran.Rollback();
throw (ex);
}
finally
{
if (conn.State != ConnectionState.Closed) //关闭链接,避免资源浪费
conn.Close();
} return rtnMsg; //对比无事务的
//OracleParameter[] paras = new OracleParameter[]
//{
// new OracleParameter("p_ass_code", ass_code),
// new OracleParameter("p_cust_model", cust_model),
// new OracleParameter("p_ship_date", ship_date),
// new OracleParameter("p_cust_name", cust_name),
// new OracleParameter("p_ship_city", ship_city), // new OracleParameter("p_ship_country", ship_country),
// new OracleParameter("p_po_cstname", po_cstname),
// new OracleParameter("p_po_no", po_no),
// new OracleParameter("p_chd_code", chd_code),
// new OracleParameter("p_batch_id", batch_id), // new OracleParameter("p_msg", OracleType.VarChar, 100)
//};
//paras[10].Direction = ParameterDirection.Output;
//DataBase.Provider.ExecuteNonQuery(CommandType.StoredProcedure, @"pkg_name.procedure_name", paras); //batch_id = Convert.ToDecimal(paras[9].Value);
//return paras[10].Value.ToString();
}

2、

public string updateSuccessFlag(DataTable dt)
{
string rtnMsg = "";
OracleConnection conn = (OracleConnection)DataBase.Provider.GetConnection();
conn.Open();
//启动事务
OracleTransaction tran = conn.BeginTransaction();
try
{
OracleCommand cmd = conn.CreateCommand();
cmd.Transaction = tran; //绑定事务
cmd.CommandType = CommandType.Text;
cmd.CommandText = @"UPDATE table_name d SET d.flag = 1 WHERE d.prodid = :prod_id"; cmd.Parameters.AddWithValue("prod_id", ""); //参数占位符 //cmd.Parameters.Add("p_msg", OracleType.VarChar, 100);
//cmd.Parameters[10].Direction = ParameterDirection.Output; foreach (DataRow dr in dt.Rows) //动态参数,我们参数
{
cmd.Parameters["prod_id"].Value = Convert.ToString(dr["PRODID"]);
cmd.ExecuteNonQuery();
}
tran.Commit();
rtnMsg = "SUCCESS";
}
catch (Exception ex)
{
tran.Rollback();
throw (ex);
}
finally
{
if (conn.State != ConnectionState.Closed)
conn.Close();
} return rtnMsg;
}

3.SQLServer简单事务

//SQL语句事务
//更新数据到SqlServer
public string UploadStbDataToHuaWei(DataTable dt)
{
string rtnMsg = "";
//获取链接,并开启链接
SqlConnection conn = (SqlConnection)DataBase.ProviderSQL.GetConnection();
conn.Open();
//启动事务
SqlTransaction tran = conn.BeginTransaction();
try
{
SqlCommand cmd = conn.CreateCommand();
cmd.Transaction = tran; //绑定事务
cmd.CommandType = CommandType.Text;
cmd.CommandText = @"insert into [database_name].[dbo].[table_name] ([bar_code] ,[type] ,[stb_value],[created_date], [updated_date])
values(
@bar_code, @type, @stb_value, GETDATE(),
GETDATE())"; cmd.Parameters.AddWithValue("@bar_code", ""); //占位符
cmd.Parameters.AddWithValue("@type", "");
cmd.Parameters.AddWithValue("@stb_value", ""); foreach (DataRow dr in dt.Rows)
{
///cmd.Parameters.Add("@bar_code", SqlDbType.VarChar); //输出 //SqlServer的事务
cmd.Parameters["@bar_code"].Value = Convert.ToString(dr["PRODID"]);
cmd.Parameters["@type"].Value = Convert.ToString(dr["TYPES"]);
cmd.Parameters["@stb_value"].Value = Convert.ToString(dr["VAL"]);
cmd.ExecuteNonQuery();
}
tran.Commit();
rtnMsg = "SUCCESS";
}
catch (Exception ex)
{
tran.Rollback();
throw (ex);
}
finally
{
if (conn.State != ConnectionState.Closed)
conn.Close();
}
return rtnMsg;
}
-------------------------------------------------------------------------------------------------------
//事务的一般写法和逻辑
SqlConnection conn = DataBase.Provider.GetConnection() as OracleConnection;
//OracleCommand cmd = conn.CreateCommand();
conn.Open();
//...创建数据库连接 cnn
System.Data.SqlClient.SqlTransaction trans = cnn.BeginTransaction();
try
{
foreach (DataRow dr in dt.Rows)
{
cm.CommandText = "update [表] set [数量] = @amount where productID = @productID";
cm.Parameters.Add("@amount", SqlDbType.Int);
cm.Parameters["@amount"].Value = Convert.ToInt32(dr["amount"]);
cm.Parameters.Add("@productID", SqlDbType.VarChar);
cm.Parameters["@productID"].Value = dr["productID"].ToString();
cm.ExecuteNonQuery();
}
trans.Commit();
}
catch
{
trans.Rollback();
} 分享共进步
谢谢阅读!

.NET的多种事务处理的更多相关文章

  1. PDO多种方式取得查询结果

    PDO多种方式取得查询结果 01 December 2009 1:26 Tuesday by Sjolzy PDO最大的特点之一是它的灵活性,本节将介绍如何取得查询结果,包括: 数组(数值或关联数组) ...

  2. JDBC 元数据 事务处理

    使用 JDBC 驱动程序处理元数据 Java 通过JDBC获得连接以后,得到一个Connection 对象,可以从这个对象获得有关数据库管理系统的各种信息,包括数据库中的各个表,表中的各个列,数据类型 ...

  3. 了解Entity Framework中事务处理

    Entity Framework 6以前,框架本身并没有提供显式的事务处理方案,在EF6中提供了事务处理的API. 所有版本的EF,只要你调用SaveChanges方法进行插入.修改或删除,EF框架会 ...

  4. XA事务处理

    XA接口详解 X/Open XA接口是双向的系统接口,在事务管理器(Transaction Manager)以及一个或多个资源管理器(Resource Manager)之间形成通信桥梁.事务管理器控制 ...

  5. 转载“启动\关闭Oracle数据库的多种方法”--来自百度#Oracle

    启动\关闭Oracle数据库的多种方法 启动和关闭oracle有很多种方法. 这里只给出3种方法: l         Sql*plus l         OEM控制台 l         Wind ...

  6. MySQL支持多种存储引擎

    MySQL的强大之处在于它的插件式存储引擎,我们可以基于表的特点使用不同的存储引擎,从而达到最好的性能. MySQL有多种存储引擎:MyISAM.InnoDB.MERGE.MEMORY(HEAP).B ...

  7. 转:有事务处理的NoSQL数据库

    原文来自于:http://www.infoq.com/cn/articles/MarkLogic-NoSQL-with-Transactions Java平台在其几乎整个生命周期中,都在煞费苦心地努力 ...

  8. 在.NET项目中使用PostSharp,使用CacheManager实现多种缓存框架的处理

    在前面几篇随笔中,介绍了PostSharp的使用,以及整合MemoryCache,<在.NET项目中使用PostSharp,实现AOP面向切面编程处理>.<在.NET项目中使用Pos ...

  9. 大数据基础篇(一):联机分析处理(OLAP) 与 联机事务处理(OLTP)

    联机事务处理(OLTP) OLTP也称实时系统(Real Time System),支持事务快速响应和大并发,这类系统典型的有ATM机(Automated Teller Machine)系统.自动售票 ...

随机推荐

  1. velocity+spring mvc+spring ioc+ibatis初试感觉(与struts+spring+hibernate比较)

    velocity+spring mvc+spring ioc+ibatis框架是我现在公司要求采用的,原因是因为阿里巴巴和淘宝在使用这样的框架,而我公司现在还主要是以向阿里巴巴和淘宝输送外派人员为 主 ...

  2. php扩展开发笔记(2)多个源代码文件的配置和编译

    我们在开发过程中,为了代码得可读性和易维护性,肯定是须要多个代码文件的,而不不过通过 ext_skel 生成得骨架文件. 这篇文章主要介绍下.多个代码文件的时候.我们须要注意什么,以及怎么做. 我的代 ...

  3. QT设置centralWidget布局

    QT设置centralWidget布局 设置之前是这样的,这时候即使设置了控件的布局,实际上控件大小还是不会跟这变,因为centralWidget没有设置布局. 需要在没有控件的空白区域,点击右键在布 ...

  4. C语言 strftime 格式化显示日期时间 时间戳

    C/C++程序中需要程序显示当前时间,可以使用标准函数strftime. 函数原型:size_t strftime (char* ptr, size_t maxsize, const char* fo ...

  5. mahout源码分析之DistributedLanczosSolver(六)完结篇

    Mahout版本:0.7,hadoop版本:1.0.4,jdk:1.7.0_25 64bit. 接上篇,分析完3个Job后得到继续往下:其实就剩下两个函数了: List<Map.Entry< ...

  6. hdu 4445 Crazy Tank

    #include <iostream> #include <cstdio> #include <cstring> #include <algorithm> ...

  7. docker 基本原理及快速入门

    作者地址:青牛 什么是docker Docker 是一个开源项目,诞生于 2013 年初,最初是 dotCloud 公司内部的一个业余项目.它基于 Google 公司推出的 Go 语言实现. 项目后来 ...

  8. vue-router 懒加载优化

    一.路由懒加载 1.先安装 babel 动态引入插件 npm install --save-dev babel-plugin-syntax-dynamic-import 2.修改router/inde ...

  9. electron项目中使用jquery不生效的解决方法

    才开始接触electron的时候,本来想用bootstrap快速搞一个demo,无奈有些功能没法用,之后才意识到是jquery没发用,之后找了一些资料,比较简单的方式就是在引入jquery之前加入一下 ...

  10. ASP.NET WebServices 因 URL 意外地以“/HelloWorld”结束,请求格式无法识别。

    今天在使用Asp.net做一个WebServices时通过Get方式调用方法时却出现了以下错误(仅在Get请求下,POST下正常)   在网络和MSDN上了解到WebServices默认只启用 Htt ...