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