- 1、本文档共10页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Oracle集合類型输出参数的PLSQL存储过程及其Java调用
Oracle集合类型输出参数的PL/SQL存储过程及其Java调用- -
??????????????????????????????????????
有段时间为了用存储过程做统计报表,写了这文章。
现在的java的数据库-关系映射技术似乎不提倡用存储过程,其实存储过程更能发挥数据库的效率。1? 引言存储过程因其执行效率高、与事务处理的结合、运行更安全等优点,在数据库应用程序中被广泛采用。PL/SQL是用于从各种环境中访问Oracle数据库的一种编程语言,它与数据库服务器集成在一起,PL/SQL编写的存储过程编译效率高,网络系统开销小,同时PL/SQL直观性好,是大多数人的选择。以Number、Varchar等基本标量类型为输出参数的PL/SQL存储过程,每个输出参数只能返回一个对应值。而在实际数据库应用程序中,尤其是在进行系统综合查询统计时,往往需要返回二维数组或结果集,这时应考虑在存储过程中使用集合这种数据结构。对于集合,我们可以一次把许多元素作为一个整体进行操作,也可以对集合中的单个元素进行操作,使用方便、灵活。?2? PL/SQL存储过程及Java程序的编写2.1? 索引表作为输出参数
索引表是无约束的,其大小的唯一限制(除可用内存外)就是它的关键字BINARY_INTEGER类型所能表示数值的约束(-2147483647...+2147483647),其元素不需要按任何特定顺序排列。在声明时,我们不需要指定其大小,而且对索引表的元素可以直接赋值,不用初始化,可见使用索引表极其方便。
2.1.1存储过程的编写我们可以在PL/SQL语句块中定义索引表,但作为输出参数的索引表,必须要在包(package)里定义,方法如下:create or replace package out_param is???????????????????????????????????????? ---- 定义了元素是varchar2类型的一个索引表类型type out_index_table_typ is table of varchar2(50) index by binary_integer;end out_param;接下来就可以在pl/sql存储过程里引用在包里定义的索引表类型:????????????????? ?create or replace procedure testPro1(in_param in varchar2,o_table out? out_param. out_index_table_typ ) is????????????????????? begin ????????????????? ????????-------这里略去程序体????????????????????? end? testPro1; ????????? 其中,返回的索引表类型前必须用包名加上句点来引用out_param. out_index_table_typ 2.1.2? Java程序的编写索引表与数据库表很形似,有key和value两列,但它不是真正的数据库表,不可以存储到数据库中。因此索引表不能使用SQL进行操作,这样它的内容不能通过一个标准的SELECT语句返回游标得到。这一点与嵌套表有很大不同。由存储过程返回的索引表可以映射成java数组类型、JDBC Datatypes的BigDecimal[]数组类型和oracle的Datum[]数组。有一点要注意,尽管索引表中的元素不一定要按任何特定顺序排列,其元素可以借助于任意有效关键字而插入,但对映射数组元素的引用应该从1开始,而且要连续,否则映射成数组时会出现null元素。下面示例为将索引表映射成java数组类型。import oracle.jdbc.*;import oracle.sql.*;import java.sql.*;public class ReturnIndexTable{? Connection ociconn=null;OracleCallableStatement stmt =null;public String[] getTable(String in_param){? String[] reAry=null;try{? OracleDriver S_Driver=null;if(S_Driver==null)S_Driver=new oracle.jdbc.OracleDriver();DriverManager.registerDriver(S_Driver);String url=jdbc:oracle:oci8:@test;String user=user;String pas
您可能关注的文档
- OracleDecode函數使用技巧大全.docx
- OracleDatabase10g性能調整与优化.docx
- OracleEBS12forwindows免安裝虚拟机或是OracleEBS12.1forlinux免安装虚拟机+最佳业务实践教程.doc
- OracleJDE812DEMO安裝手册.doc
- Oracle_group_by_用法實例详解.doc
- Oracle_EBS_Discoverer實例详解.doc
- oracle_11gR2_RAC_on_AIX6.1_安裝手册.doc
- oracle_PLSQL_語法详细手册.doc
- Oracle_RMAN_詳解与实例(Linux).doc
- oracle_sql性能優化.doc
- 2024宁波卫生职业技术学院《形势与政策》期末考试自我提分评估附参考答案详解【基础题】.docx
- 2024-2025学年温州大学《形势与政策》期末考试模拟试题含答案详解【综合题】.docx
- 2024-2025学年江西航空职业技术学院《形势与政策》期末考试题库试题附参考答案详解【预热题】.docx
- 2024-2025学年度潍坊食品科技职业学院《形势与政策》期末考试考前冲刺试卷及答案详解(夺冠系列).docx
- 2024-2025学年渤海理工职业学院《形势与政策》期末考试试卷及参考答案详解(巩固).docx
- 2024-2025学年青海建筑职业技术学院《形势与政策》期末考试经典例题带答案详解(精练).docx
- 2024-2025学年度湖北幼儿师范高等专科学校《形势与政策》期末考试常考点试卷(研优卷)附答案详解.docx
- 2025河北美术学院《形势与政策》期末考试试题及参考答案详解AB卷.docx
- 2025年上海大学《形势与政策》期末考试经典例题及答案详解【易错题】.docx
- 2025年山东经贸职业学院《形势与政策》期末考试考试黑钻押题附完整答案详解【考点梳理】.docx
文档评论(0)