>>分享孙卫琴的Java技术专稿和著作 书籍支持  卫琴直播  品书摘要  在线测试  资源下载  联系我们
发表一个新主题 开启一个新投票 回复文章 您是本文章第 21504 个阅读者 刷新本主题
 * 贴子主题:  【持久化专题】通过JPA API调用存储过程 回复文章 点赞(0)  收藏  
作者:sunweiqin    发表时间:2021-05-05 07:19:32     消息  查看  搜索  好友  邮件  复制  引用

本文参考《精通JPA与Hibernate:Java对象持久化技术详解》,作者:孙卫琴,清华大学出版社出版
  
以下SQL代码定义了一个名为findCustomers的存储过程,p_age为输入参数,p_count为输出参数:    
delimiter  //
create procedure findCustomers(in p_age integer,out p_count integer)
begin
select count(*) into p_count from CUSTOMERS where AGE>p_age;
select name from CUSTOMERS;
end  //

  JPA API中的StoredProcedureQuery接口能够调用存储过程,并且还能设置输入参数,以及读取输出参数:    

StoredProcedureQuery query=entityManager
           .createStoredProcedureQuery("findCustomers");

//注册参数
query.registerStoredProcedureParameter(1,
                           Integer.class,ParameterMode.IN);
query.registerStoredProcedureParameter(2,
                           Integer.class,ParameterMode.OUT);
int age=15;
query.setParameter(1,age); //设置参数
List names=query.getResultList();  //调用存储过程

for(Object name:names)  //遍历查询结果
  System.out.println((String)name);

//读取输出参数
System.out.println("年龄大于"+age+"的客户数目:"
          +(Integer)query.getOutputParameterValue(2));

点击在新窗口中浏览原图
CTRL+鼠标滚轮放大或缩小

程序猿的技术大观园:www.javathinker.net





[这个贴子最后由 admin 在 2021-10-09 10:44:56 重新编辑]
  Java面向对象编程-->集合(下)
  JavaWeb开发-->Web运作原理(Ⅳ)
  JSP与Hibernate开发-->域对象在持久化层的四种状态
  Java网络编程-->通过JDBC API访问数据库
  精通Spring-->Vue CLI脚手架工具
  Vue3开发-->创建综合购物网站应用
  【Vue.js技术专题】Vue组件的命名规则
  【Vue.js技术专题】命名路由
  【Vue.js技术专题】自定义指令范例:v-drag指令
  【Spring Cloud Alibaba专题】Nacos配置属性的持久化
  【持久化专题】为什么JPA和Hibernate的持久化方法都抛出运行...
  【Spring专题】服务器端推送
  【Spring专题】控制器对象的生命周期
  【Java网络编程专题】用java.net.URL类访问HTTP服务器读取网...
  【Java网络编程专题】盘点用Java抓取HTTP服务器和FTP服务器的...
  【Java网络编程专题】创建基于SSL的安全服务器和安全客户的范...
  【Java网络编程专题】优化访问数据库的程序代码的一些技巧
  【JavaWeb专题】在JavaWeb应用中对客户请求的异步处理
  IT技术书写作技巧分享:慎用概念和术语
  【Java基础编程专题】定时器Timer类的用法
  【Java基础编程专题】为什么说:继承关系最大的弱点就是打破...
  更多...
 IPIP: 已设置保密
楼主      
1页 0条记录 当前第1
发表一个新主题 开启一个新投票 回复文章


中文版权所有: JavaThinker技术网站 Copyright 2016-2026 沪ICP备16029593号-2
荟萃Java程序员智慧的结晶,分享交流Java前沿技术。  联系我们
如有技术文章涉及侵权,请与本站管理员联系。