栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

JPA Hibernate调用Postgres函数无效返回MappingException:

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

JPA Hibernate调用Postgres函数无效返回MappingException:

我对JPA有足够的了解,试图使其运行存储过程。

我最终使用带准备好的语句的JDBC。在花了几个小时的徒劳尝试将方钉插入圆孔后,我在15分钟内做到了。我将持久性单元用来获取连接,创建准备好的语句并在完成后将其关闭的同一个jndi数据源称为。

因此,如果您需要从(现在主要是)JPA应用程序运行存储过程(或Postgres函数),这对我有用:

@Stateless@LocalBeanpublic class UserQueryBean implements Serializable {    @Resource(mappedName="jdbc/DatabasePool")     private javax.sql.DataSource ds;    ...    public void runRequestCleanup() {        String queryString = "SELECT cleanup_function_that_hibernateJPA_choked_on()";        Connection conn = null;        PreparedStatement statement = null;        try { conn = ds.getConnection(); statement = conn.prepareCall(queryString); statement.executeQuery();        } catch (SQLException ex) { Logger.getLogger(UserQueryBean.class.getName()).log(Level.SEVERE, null, ex);        }finally{ try {     statement.close();     conn.close(); } catch (SQLException ex) {     Logger.getLogger(UserQueryBean.class.getName()).log(Level.SEVERE, null, ex); }        }        // bit of logging pre here        }    ...}

忽略JPA在服务器上运行函数或存储过程的简单功能似乎令人恐惧。特别是除了void或受影响的行数以外不返回任何内容的代码。如果是故意的……则无可奉告。

编辑:添加了关闭连接。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/393178.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号