当前位置: 首页 > 图文教程 > 网络编程 > ASP.NET > .net分布式事务例子

ASP.NET
asp.net 转换人民币大小金额
编写的vs2005水晶报表程序在vs2008下正常使用的一些实现方法
asp.net下获取浏览器类型的实现代码
asp.net coolite 删除时弹出确定按钮
asp.net Forms身份验证和基于角色的权限访问
asp.net 用继承方法实现页面判断session
asp.net DataGrid 中文字符排序的实现代码
asp.net 利用IIS的404错误将文件重写成目录的简单方法
Aspx/Asp.net 防注入程序 V1.0
C# 数组查找与排序实现代码
ASP.NET通过使页面动态加载不同CSS实现多界面
LINQ学习笔记:XDocument文档与XML声明
ASP.NET教程:如何动态写入服务器端控件
XML+XSLT+CSS+JQuery+WebService组建Asp.Net网站
ASP.NET效率陷阱之:Attributes
.NET vs J2EE:面对SOA的荒谬与误解
ASP.NET学习篇(1):开篇
ASP.NET学习篇(2):安装与配置
ASP.NET学习篇(3):几个简单的ASP.ENT的例子
ASP.NET学习篇(4):服务器端的控件

ASP.NET 中的 .net分布式事务例子


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-11-03   浏览: 101 ::
收藏到网摘: n/a


using System;//引用系统命名空间
using System.Data.OleDb;//引用ADO.net命名空间
using System.Data;//引用数据空间
using System.Runtime.InteropServices;//为了调用GUID
using System.EnterpriseServices;//引用COM+名命空间
using System.Runtime.CompilerServices;//运行时编译服务器
using System.Reflection;//用些全局属性取得强名属性
using System.Data.SqlClient;
[assembly: ApplicationName("COMLibrary")]
//强名文件名和文件属性。用sn.exe生成,用法 sn -k clsStock.snk
//[assembly: AssemblyKeyFileAttribute("clsStock.snk")]
//[assembly: AssemblyKeyName("clsStock.snk")]
[assembly: AssemblyKeyFileAttribute("..\\..\\clsStock.snk")]
[assembly: AssemblyKeyName("..\\..\\clsStock.snk")]
namespace COMLibrary
{
[Transaction(TransactionOption.Required)]
public class DBOperation:ServicedComponent
{
private SqlConnection myConnection;
private SqlCommand myCommand;
///
/// connect database
///


///
database config infomation
/// formatting : datasource=..;user id=..;password=...
///

///
public void Connect()
{
string connection="workstation id=YANLIXIN;packet size=4096;user id=sa;data source=\"yanlixin\\scgl\";p" +
"ersist security info=True;initial catalog=scgl;password=scgl";
//
myConnection = new SqlConnection( connection );
myConnection.Open();
myCommand = new SqlCommand();
myCommand.Connection = myConnection;

return;
}
///
/// Execute one insert statement and insert one record into the table
///

///
database config infomation
/// formatting : datasource=..;user id=..;password=...
///

///
public int CommandExcute(string commandstring)
{
int returnValue = 0;
myCommand.CommandText = commandstring;
returnValue = myCommand.ExecuteNonQuery();

return returnValue;
}
///
/// Commit the com+ transaction
///

public void Commit()
{
ContextUtil.SetComplete();
if(myConnection!=null)
myConnection.Close();
}
///
/// Roolback the com+ transaction
///

public void Abort() { ContextUtil.SetAbort(); if(myConnection!=null) myConnection.Close(); } }}