Chinaunix
标题:
sybase CT-LIBRARY有关事务的问题
[打印本页]
作者:
onku
时间:
2007-04-17 19:42
标题:
sybase CT-LIBRARY有关事务的问题
使用sybase CT-LIBRARY连接sybase数据库。
现在要实现一个如下功能:
begin tran
insert tablea
update tableb
commit tran
这个语句是我在前台界面拼出来的,然后通过ctlib接口提交给sybase数据库。
但是结果是数据库不会把这个sql看成一个事务。如果insert失败了,不会回滚退出,而是继续之行update,并且如果update成功了,就会返回一个成功的标志给我。
问题1:sql自己好像不能保证事务的完整性吧?
问题2:如果sql自己不能保证,那么,ctlib中有没有像其他编程语言一样有一些类似
ct_begintran()
ct_commit()
ct_rollback()
这样的接口。例如下面这段java代码:
Connection conn = DataSourceUtils.getConnection(); //建立一个连接
try {
conn.setAutoCommit(false);
//insert
//update
conn.commit();//像这样的用手工提交一个事务
}
catch (Exception e) {
DataSourceUtils.rollback(conn);//如果失败,手工回滚。
}
目前想到的解决办法是将这个业务逻辑放到存储过程里面去,然后前台调用存储过程。
不知道大家有没有更好的方法。
如果ctlib里有控制事务的接口用是最好的了。
作者:
onku
时间:
2007-04-18 17:51
难道我没有说清楚?
还是cu的牛们都吃草去了,不来挤奶了?
欢迎光临 Chinaunix (http://bbs.chinaunix.net/)
Powered by Discuz! X3.2