免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2366 | 回复: 1
打印 上一主题 下一主题

sybase CT-LIBRARY有关事务的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-04-17 19:42 |只看该作者 |倒序浏览
使用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里有控制事务的接口用是最好的了。

论坛徽章:
0
2 [报告]
发表于 2007-04-18 17:51 |只看该作者
难道我没有说清楚?


还是cu的牛们都吃草去了,不来挤奶了?
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP