Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 1076|回复: 0

如何将ORACLE中的RECORD等数据类型移植到DB2

[复制链接]

该用户从未签到

发表于 2011-10-29 12:54:07 | 显示全部楼层 |阅读模式
本人目前在进行ORACLE到DB2的存储过程移植,但DB2初次接触。

目前有段程序,如下:
包头:定义了一个TYPE
  TYPE USER IS RECORD
  (
  name varchar2(50),
  age number(2)
  );
  TYPE cur_user IS REF CURSOR RETURN USER ;

包体:定义输出参数为USER 类型,使用动态游标查询结果并赋值给USER类型变量,在客户端程序中获得结果集,
  PROCEDURE GET_USER(v_cur_user OUT cur_user)   
  IS
  BEGIN  
  OPEN v_cur_user FOR
  SELECT name,age FROM user WHERE .....
  END;

具体程序细节我简化了,流程就是这样,客户端是JDBC的通用接口,这个不需要移植。
请问DB2的存储过程有类似的写法吗,哪位高人能帮帮我?
回复

使用道具 举报

该用户从未签到

发表于 2011-10-29 12:54:11 | 显示全部楼层
oracle这个东西看不懂
回复 支持 反对

使用道具 举报

该用户从未签到

发表于 2011-10-29 12:54:22 | 显示全部楼层
不是用临时表代替,就是程序移植,将ORACLE的对应类型在DB2中找到,目前我还在查,DB2的资料不多,本人也是DB2的菜鸟
回复 支持 反对

使用道具 举报

该用户从未签到

发表于 2011-10-29 12:54:23 | 显示全部楼层
db2里似乎都没法实现,取代方案:
你定义一个临时表,把游标的结果集放到临时表
回复 支持 反对

使用道具 举报

该用户从未签到

发表于 2011-10-29 12:54:31 | 显示全部楼层
我有很多这样的TYPE类型啊,至少五十个。
我查了下DB2好像也有TYPE类型,版本是9.5,但是没有使用的例子
回复 支持 反对

使用道具 举报

该用户从未签到

发表于 2011-10-29 12:54:40 | 显示全部楼层
用户自定义类型只是一种类型,不是一个表
回复 支持 反对

使用道具 举报

该用户从未签到

发表于 2011-10-29 12:54:44 | 显示全部楼层
我的意思是DB2也有用户自定义类型,应该没必要另外创建临时表,但是我不知道怎么和游标结合起来使用
回复 支持 反对

使用道具 举报

该用户从未签到

发表于 2011-10-29 12:54:46 | 显示全部楼层
你说的UDT在相关文档中只见对单值类型的操作 而对于引用类型以及结构化类型没有相应的文档支持
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

GMT+8, 2024-5-22 18:23 , Processed in 0.368656 second(s), 33 queries .

Powered by Discuz! X3.4

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表