当前位置: 代码迷 >> DB2 >> DB2 存储过程解决方案
  详细解决方案

DB2 存储过程解决方案

热度:1411   发布时间:2013-02-26 00:00:00.0
DB2 存储过程
在存储过程中,select ID from A; 假如结果如下:
ID
1
2
3
4
5
这就像是个链式的记录,
怎样在游标中能够取到这样结构的数据:
ID, ID'
1, 2
2, 3
3, 4
4, 5
5
,
这就像是将链式记录分成一段段。兄妹们,怎么做呀,我想用2个游标可以做到,但是效率蛮低下的,可能可以用临时表,但是不会。

------解决方案--------------------------------------------------------
1. DB2的临时表需要用命令Declare Temporary Table来创建, 并且需要创建在用户临时表空间上;

  2. DB2在数据库创建时, 缺省并不创建用户临时表空间, 如果需要使用临时表, 则需要用户在创建临时表之前创建用户临时表空间;

  3. 临时表的模式为SESSION;

  4. 缺省情况下, 在Commit命令执行时, 临时表中的所有记录将被删除; 这可以通过创建临时表时指定不同的参数来控制;

  5. 运行ROLLBACK命令时, 用户临时表将被删除;

  6. 在DB2版本8中, 可以对临时表纪录日志;


------解决方案--------------------------------------------------------
如果是这种连接的,可以这么写:
SQL code
select id,id+1 from A
------解决方案--------------------------------------------------------
你还是说说你想实现一个什么样的功能,你的想法不一定是最好的解决方案
  相关解决方案