热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

存储过程返回结果转化为对象属性值的方法-bbosspersistento/rmapping机制应用

bbosspersistentormapping机制能够将存储过程调用过程中out参数转化为对象属性返回给应用程序。本文档举例说明这个功能。java值对象Test_p,定义好属性及属

bboss persistent o/r mapping机制能够将存储过程调用过程中out参数转化为对象属性返回给应用程序。本文档举例说明这个功能。

java值对象Test_p,定义好属性及属性的set/get方法
public class Test_p {
        private String test;
        private String name;
        private String name1;
        private int count = 0;
        public String getName() {
                return name;
        }
        public void setName(String name) {
                this.name = name;
        }
        public String getName1() {
                return name1;
        }
        public void setName1(String name1) {
                this.name1 = name1;
        }
        public String toString()
        {
                return new StringBuffer().append("name=").append(name).append(",name1=").append(name1).append(",test=").append(test).toString();
        }
        public String getTest() {
                return test;
        }
        public void setTest(String test) {
                this.test = test;
        }
        public int getCount() {
                return count;
        }
        public void setCount(int count) {
                this.count = count;
        }

}

定义存储过程,存储过程中的out参数名称与java对象Test_p的属性保持一致,bboss persistent 提供的or mapping机制将自动在procedure的out参数名称和java对象的属性之间进行撮合,匹配上的属性和参数将会进行值与值的设置,如果二者之间的数据类型不一致,那么只要能够转换 框架将会进行自动转换。

CREATE OR REPLACE PROCEDURE test_p(id in number,
                                   name out varchar2 --本参数与Test_p对象中的name属性对应,并且类型一致,不需要类型转换
                                ,name1 out varchar2,--本参数在Test_p对象中的name1属性对应,并且类型一致,不需要类型转换                                  
                                   test out number,--本参数在Test_p对象中的test属性对应,但是类型不一致,一个是number,一个是String,需要类型转换,即number将被转换为String类型
                                   notmatch out number --本参数在Test_p对象中没有对应属性,将被忽略
) IS

/******************************************************************************
   NAME:       test
   PURPOSE:   

   REVISIONS:
   Ver        Date        Author           Description
   ---------  ----------  ---------------  ------------------------------------
   1.0        2008-10-27          1. Created this procedure.

   NOTES:

   Automatically available Auto Replace Keywords:
      Object Name:     test
      Sysdate:         2008-10-27
      Date and Time:   2008-10-27, 17:05:33, and 2008-10-27 17:05:33
      Username:         (set in TOAD Options, Procedure Editor)
      Table Name:       (set in the "New PL/SQL Object" dialog)

******************************************************************************/
BEGIN
   --tmpVar := 0;
   name := 'hello name';
   name1 := 'hello name1';
   test := id;
   notmatch := id;
   --insert into test(id,name) values(SEQ_TEST.nextval,'name1');
   --commit;
  
  
EXCEPTION
  WHEN NO_DATA_FOUND THEN
    NULL;
  WHEN OTHERS THEN
    -- Consider logging the error and then re-raise
    RAISE;
END test_p;
/

业务方法

CallableDBUtil callableDBUtil = new CallableDBUtil();
                try
                {
                        callableDBUtil.prepareCallable("{call test_p(?,?,?,?,?)}");
                        //不允许的操作: Ordinal binding and Named binding cannot be combined!
                        callableDBUtil.setInt("id", 10);
                        callableDBUtil.registerOutParameter("name", java.sql.Types.VARCHAR);
                        callableDBUtil.registerOutParameter("name1", java.sql.Types.VARCHAR);
                        callableDBUtil.registerOutParameter("test", java.sql.Types.INTEGER);
                        callableDBUtil.registerOutParameter("nomatch", java.sql.Types.INTEGER);
                        Test_p tets = (Test_p)callableDBUtil.executeCallableForObject(Test_p.class);
                       
                        System.out.println("Test_p is " + tets);
                                       
                }
                catch(Exception e)
                {
                        e.printStackTrace();
                } 

 

bboss项目下载列表 在sourceforge访问地址为:
https://sourceforge.net/project/showfiles.php?group_id=238653

     


推荐阅读
  • 抽空写了一个ICON图标的转换程序
    抽空写了一个ICON图标的转换程序,支持png\jpe\bmp格式到ico的转换。具体的程序就在下面,如果看的人多,过两天再把思路写一下。 ... [详细]
  • 目录实现效果:实现环境实现方法一:基本思路主要代码JavaScript代码总结方法二主要代码总结方法三基本思路主要代码JavaScriptHTML总结实 ... [详细]
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • GetWindowLong函数
    今天在看一个代码里头写了GetWindowLong(hwnd,0),我当时就有点费解,靠,上网搜索函数原型说明,死活找不到第 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • 本文介绍了Redis的基础数据结构string的应用场景,并以面试的形式进行问答讲解,帮助读者更好地理解和应用Redis。同时,描述了一位面试者的心理状态和面试官的行为。 ... [详细]
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • 使用Ubuntu中的Python获取浏览器历史记录原文: ... [详细]
  • 使用在线工具jsonschema2pojo根据json生成java对象
    本文介绍了使用在线工具jsonschema2pojo根据json生成java对象的方法。通过该工具,用户只需将json字符串复制到输入框中,即可自动将其转换成java对象。该工具还能解析列表式的json数据,并将嵌套在内层的对象也解析出来。本文以请求github的api为例,展示了使用该工具的步骤和效果。 ... [详细]
  • ZSI.generate.Wsdl2PythonError: unsupported local simpleType restriction ... [详细]
  • 超级简单加解密工具的方案和功能
    本文介绍了一个超级简单的加解密工具的方案和功能。该工具可以读取文件头,并根据特定长度进行加密,加密后将加密部分写入源文件。同时,该工具也支持解密操作。加密和解密过程是可逆的。本文还提到了一些相关的功能和使用方法,并给出了Python代码示例。 ... [详细]
  • 第一步:PyQt4Designer设计程序界面该部分设计类同VisvalStudio内的设计,改下各部件的objectName!设计 ... [详细]
author-avatar
大海2502902497
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有