`
midstr
  • 浏览: 33435 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

sybase事务中调用含有临时表的存储过程的问题

阅读更多
原来调用存储过程的地方都没有使用事务,当然里面包括多个表的更新操作,使用都很正常。后来我给加上了jdbc事务,代码如下:
引用:
TransactionStatus status = super.beginTransaction();
                try {
                        map = getFtglUtils().cancelFtrw(getPageAjlb(),
                                        key.getId1().intValue(), key.getId2().intValue(), qxyy,
                                        iState);
                        super.getTransactionManager().commit(status);
                } catch (Exception e) {
                        super.getTransactionManager().rollback(status);
                        throw new SystemException(e);
                }
加上事务之后就发现存储过程没有完全执行,里面的update语句都没有执行,但是最后的select还能返回结果集,调用后台也不报错……百思不得其解。后来凑巧把存储过程中创建临时表的如下语句
引用:
-- 创建临时表
          create table #tmpBAGL
          (
              BH int,                    -- 编号
              RWXH smallint              -- 任务序号
          )  
移到了使用这个临时表的if else里面,因为只有在一定的条件下才需要创建临时表。再试了一下调用存储过程,发现一切正常了!这一次存储过程没有执行创建临时表,就正常了……遂上网搜到一个如下的描述:
引用:
select into可以在事务中使用,但是前提条件是这个事务只有select into一条语句。
SELECT INTO command not allowed within multi-statement transaction.  
注意是multi-statement transaction
大家都知道,select into #tabel的最大优势是速度快,但这个速度快是用不记录日志来实现的。
而使用事务的目的就是要么事务中的所有操作全部执行,要么所有操作全部回滚。
这是靠日志中记录的操作来保证的。
如果select into可以在多语句的事务中使用,但是它本身又是不计日志的,也就是不能回滚的。
这就和事务的定义矛盾了。
因此,select into不能在多语句的事务中使用。
但也不是说我们不能使用select into这个好东东,set chained off,使用非链式事务或者把select into
放在单独一个事务中运行就可以了。
还有一个在多语句事务中被禁止的,而在应用中会常需要的命令是truncate table。
原因和解决方法也如上所说。
把存储过程还原成最开始那样,在创建临时表之前加上set chained off,再次运行问题解决。
分享到:
评论

相关推荐

    Sybase临时表技术的多层级应用研究.pdf

    2. **存储过程优化**:在存储过程中,临时表可以分解复杂的事务处理,减少并发压力,提高查询效率。例如,可以先将大量数据加载到临时表中,然后分批处理,降低系统负担。 3. **性能提升**:通过临时表,开发者可以...

    存储过程脚本

    这包括了解如何正确处理错误,使用临时表来暂存中间结果,以及利用存储过程的性能优化技巧,如索引和查询计划分析。同时,为了便于团队协作和代码版本控制,通常会将这些脚本文件纳入源码管理工具,如Git,这也是...

    Sybase IQ 15.1引用手册(Bulding Blocks,Tables,and Procedures)

    存储过程是一种预编译的 SQL 脚本,它可以被多次调用来执行特定任务,如数据处理、事务处理等。在 Sybase IQ 中,存储过程具有以下特点: - **参数化**: 存储过程可以接受输入参数,并返回输出值。 - **可重用性**:...

    使用 Sybase SQL Expert 12.5 作数据库性能优化

    这可能包括减少不必要的数据传输、优化循环结构、避免临时表的过度使用,以及确保存储过程的参数化。 3. **索引策略**:合理地创建和使用索引可以加快数据检索速度。 Sybase SQL Expert 可以帮助分析索引的使用情况...

    SYBASE 数据库ASE15.5管理指南

    - 在tempdb中创建临时表是一种常见的做法,用于存储中间结果或进行临时数据处理。 **sybsecurity数据库** - 专门用于存储与安全性相关的信息,如用户账户和角色。 **sybsystemdb数据库** - 存储有关系统内部状态...

    Sybase语法大全

    存储过程是一组预编译的SQL语句,可以通过调用执行。它们提高了代码的重用性并可能提升性能。 11. **触发器**: 触发器是自动执行的程序,当对数据库进行特定操作(如INSERT, UPDATE, DELETE)时触发。 12. **...

    Transact-SQL开发指南

    9. **高级主题**:如联接视图、临时表、动态SQL等,进一步提升Transact-SQL的使用技巧。 通过深入学习和实践《Transact-SQL开发指南》,无论你是SQL Server还是Sybase的开发者,都能提高你的数据库管理技能,更好地...

    编程(db2)使用技巧

    与Sybase或Oracle不同,DB2的临时表在会话结束时自动删除,因此适合于存储临时数据,但不适用于跨会话的数据存储。 #### 1.3 获取当前行 在DB2中,获取当前行可以通过`FETCH FIRST`子句实现。例如: ```sql SELECT...

    DB2编程序小小技巧

    - 事务级临时表则在整个事务过程中有效,直到该事务被提交或回滚。 #### 3. 获取当前行 - **SQL查询**: ```sql SELECT * FROM tb_market_code FETCH FIRST 1 ROWS ONLY; ``` - **变量赋值**: ```sql SELECT...

    SQL Server 初级最全面知识点

    SQL Server 2008是其中的一个重要版本,它提供了4个系统数据库,包括Master(记录系统级别信息)、Tempdb(保存临时表和存储过程)、Model(作为创建新数据库的模板)以及Msdb(支持SQL Server代理的警报和作业调度...

    IQ参考手册_语句和选项_ZHS.pdf

    - **CALL**:用于调用存储过程或函数。 - **CASE**:用于根据不同的条件执行不同的 SQL 命令。 - **CHECKPOINT**:用于强制将缓存中的数据写入磁盘,确保数据一致性。 - **CLEAR**:用于清除当前环境中的临时...

    Oracle 笔记.docx

    - **调用函数与过程**:通过PreparedStatement执行存储过程或函数。 - **DAO封装**:Data Access Object模式,封装数据访问逻辑。 以上内容涵盖了Oracle数据库的基础知识、核心概念以及相关技术和操作要点,旨在...

Global site tag (gtag.js) - Google Analytics