EJB3.0调用存储过程实例教程
需积分: 0 161 浏览量
更新于2024-09-16
收藏 36KB DOC 举报
"本教程主要讲解了如何在EJB3.0环境中调用存储过程,包括无返回值和返回单值的存储过程。通过EntityManager对象的createNativeQuery()方法来执行SQL语句,实现对存储过程的调用。"
在Java企业版(J2EE)开发中,EJB(Enterprise JavaBeans)是用于构建可部署在服务器上的组件化应用的重要技术。EJB3.0作为其一个版本,引入了许多简化开发的特性,其中包括对存储过程的调用。存储过程在数据库管理中常用于封装复杂的业务逻辑或提高数据操作性能。
调用存储过程的方法是通过EntityManager对象的`createNativeQuery()`方法,该方法允许开发者执行原生的SQL语句,而不是使用EJB QL(Entity Bean Query Language)。调用存储过程的SQL格式通常为`{call 存储过程名称(参数1, 参数2,...)}`。
1. 调用无返回值的存储过程
在这个例子中,我们创建了一个名为`AddPerson`的存储过程,它向`person`表中插入一条新的记录。在EJB3.0中,调用此类存储过程的代码如下:
```java
@PersistenceContext
protected EntityManager em;
private String queryNoneReturnValueStoreProcedure() {
// 调用无返回参数的存储过程
Query query = em.createNativeQuery("{call AddPerson()}");
query.executeUpdate();
StringBuffer out = new StringBuffer("* QueryNoneReturnValueStoreProcedure 结果打印 <BR>");
return out.toString();
}
```
在这段代码中,`createNativeQuery()`方法被用来创建一个查询对象,然后调用`executeUpdate()`执行存储过程。由于存储过程没有返回值,所以这里只需执行更新操作即可。
2. 调用返回单值的存储过程
对于返回单个值的存储过程,例如`GetPersonName`,它接受一个INTEGER类型的参数并返回一个结果。以下是如何调用这样一个存储过程的示例:
```java
CREATEPROCEDURE GetPersonName(IN Pid INTEGER(11))
NOT DETERMINISTIC
SQL SECURITY DEFINER
COMMENT ''
// 在Java代码中调用
private String querySingleValueStoreProcedure(int id) {
// 调用返回单值的存储过程
Query query = em.createNativeQuery("{call GetPersonName(?)}");
query.setParameter(1, id);
Object result = query.getSingleResult();
return result.toString();
}
```
这里,`createNativeQuery()`方法中的问号`?`是一个占位符,`setParameter()`方法用于设置对应的输入参数。调用`getSingleResult()`方法获取存储过程返回的单个结果。
需要注意的是,EJB3.0不支持调用那些通过OUT参数返回值的存储过程。如果需要处理这类存储过程,可能需要使用其他方法,如直接使用JDBC连接进行操作。
总结来说,EJB3.0提供了一种简单的方式来调用存储过程,这使得开发者能够利用数据库的内置功能,同时保持代码的模块化和可维护性。通过`createNativeQuery()`方法,我们可以灵活地与数据库进行交互,执行存储过程并获取结果。在实际开发中,根据存储过程的具体需求,选择合适的方法进行调用,可以极大地提升应用的效率和性能。
2013-03-30 上传
2008-08-28 上传
2008-07-28 上传
2008-10-26 上传
2008-10-27 上传
2007-07-14 上传
点击了解资源详情
2011-10-21 上传
2009-05-29 上传
幸运小侯子
- 粉丝: 730
- 资源: 50
最新资源
- 构建基于Django和Stripe的SaaS应用教程
- Symfony2框架打造的RESTful问答系统icare-server
- 蓝桥杯Python试题解析与答案题库
- Go语言实现NWA到WAV文件格式转换工具
- 基于Django的医患管理系统应用
- Jenkins工作流插件开发指南:支持Workflow Python模块
- Java红酒网站项目源码解析与系统开源介绍
- Underworld Exporter资产定义文件详解
- Java版Crash Bandicoot资源库:逆向工程与源码分享
- Spring Boot Starter 自动IP计数功能实现指南
- 我的世界牛顿物理学模组深入解析
- STM32单片机工程创建详解与模板应用
- GDG堪萨斯城代码实验室:离子与火力基地示例应用
- Android Capstone项目:实现Potlatch服务器与OAuth2.0认证
- Cbit类:简化计算封装与异步任务处理
- Java8兼容的FullContact API Java客户端库介绍