EJB3 调用的存储过程
要调用存储过程,我们可以通过 EntityManager 对象的 createNativeQuery()方法执行 SQL 语句
(注意:这里说的是SQL 语句,不是 EJB3 QL),
调用存储过程的 SQL 格式如下:
{call 存储过程名称(参数 1, 参数 2, …)}
在 EJB3 中你可以调用的存储过程有两种
1.无返回值的存储过程。
2.返回值为 ResultSet(以 select 形式返回的值)的存储过程,EJB3 不能调用以 OUT 参数返回值的存储过程。
下面我们看看几种具有代表性的存储过程的调用方法.
1 调用无返回值的存储过程
我们首先创建一个名为 AddPerson 的存储过程,他的 DDL 如下(注:本例使用的是Sql2000 数据库):
CREATE PROCEDURE `AddPerson`() NOT DETERMINISTIC
SQL SECURITY DEFINER COMMENT ''
BEGIN
INSERT into person values( null,'存储过程',1,25,'1980');
END;
下面的代码片断展示了无返回值存储过程的调用方法:
@PersistenceContext
protected EntityManager em;
…
private String QueryNoneReturnValueStoreProcedure(){
//调用无返回参数的存储过程
Query query = em.createNativeQuery("{call AddPerson()}");
query.executeUpdate();
StringBuffer out = new StringBuffer("*************** QueryNoneReturnValueStoreProcedure 结果打印 ****************<BR>");
return out.toString();
}
2 调用返回单值的存储过程
我们首先创建一个名为 GetPersonName 的存储过程,他有一个 INTEGER 类型的输入参数,存储过程的 DDL 如 下(注:本例使用的是Sql2000数据库):
CREATE PROCEDURE `GetPersonName`(IN Pid INTEGER(11)) NOT DETERMINISTIC
SQL SECURITY DEFINER COMMENT ''
BEGIN
select personname from person where `personid`=Pid;
END;
上面的 select 语句不一定要从表中取数据,你也可以这样写:select ‘foshanren’
下面的代码片断展示了返回单值的存储过程的调用方法:
@PersistenceContext protected EntityManager em;
…
private String QuerySingleObjectStoreProcedure(){
//调用返回单个值的存储过程
Query query = em.createNativeQuery("{call GetPersonName(?)}");
query.setParameter(1, new Integer(1));
String result = query.getSingleResult().toString();
StringBuffer out = new StringBuffer("*************** QuerySingleObjectStoreProcedure 结果打
印 ****************<BR>"); out.append("返回值(人员姓名)为:"+ result+ "<BR>"); return out.toString();
}
3 调用返回表全部列的存储过程
我们首先创建一个名为 GetPersonList 的存储过程,他的 DDL 如下(注:本例使用的是Sql2000数据库):
CREATE PROCEDURE `GetPersonList`() NOT DETERMINISTIC
SQL SECURITY DEFINER COMMENT ''
BEGIN
select * from person;
END;
下面的代码片断展示了返回表全部列的存储过程的调用方法,我们可以让 EJB3 Persistence 运行环境将列值直接
填充入一个 Entity 的实例(本例填充进 Person 对象),并将实例作为结果返回.
@PersistenceContext protected EntityManager em;
…
private String QueryStoreProcedure(){
//调用返回 Person 全部列的存储过程
Query query = em.createNativeQuery("{call GetPersonList()}", Person.class); List result = query.getResultList();
StringBuffer out = new StringBuffer("*************** QueryStoreProcedure 结果打印
****************");
if (result!=null){
Iterator iterator = result.iterator();
while( iterator.hasNext() ){
Person person= (Person)iterator.next();
out.append(person.getName()+ "<BR>");
}
}
return out.toString();
}
4 调用返回部分列的存储过程
我们首先创建一个名为 GetPersonPartProperties 的存储过程,他的 DDL 如下(注:本例使用的是Sql2000数据库):
CREATE PROCEDURE `GetPersonPartProperties`() NOT DETERMINISTIC
SQL SECURITY DEFINER
COMMENT '' BEGIN
SELECT personid, personname from person;
END;
上面的 select 语句不一定要从表中取数据,你也可以这样写:select 3000, ‘foshanren’
下面的代码片断展示了返回部分列的存储过程的调用方法.
@PersistenceContext protected EntityManager em;
…
private String QueryPartColumnStoreProcedure(){
//调用返回部分列的存储过程
Query query = em.createNativeQuery("{call GetPersonPartProperties()}"); List result = query.getResultList();
StringBuffer out = new StringBuffer("*************** QueryPartColumnStoreProcedure 结果打印
****************");
if (result!=null){
Iterator iterator = result.iterator();
while( iterator.hasNext() ){
//取每一行
Object[] row = ( Object[]) iterator.next();
//数组中的第一个值是 personid
int personid = Integer.parseInt(row[0].toString()); String PersonName = row[1].toString();
out.append("人员 ID="+ personid+ "; 姓名="+PersonName+ "<BR>");
}
}
return out.toString();
}
SQL2000的存储过程调用
create table person(
personid int primary key ,
personname varchar(10) not null,
age varchar(10) not null,
sex varchar(10) not null
)
select * from person
create procedure addperson
as
begin
INSERT into person values( 1,'存储过程',1,25);
end
create procedure getperson
@pid int
as
begin
select personname from person where personid=@pid;
end
create procedure getonepart
as
begin
select personid ,personname from person ;
end
create procedure getAllperson
as
begin
select * from person ;
end
EJB3 调用的存储过程的更多相关文章
- PHP调用MYSQL存储过程实例
PHP调用MYSQL存储过程实例 标签: mysql存储phpsqlquerycmd 2010-09-26 11:10 11552人阅读 评论(3) 收藏 举报 实例一:无参的存储过程$conn = ...
- LoadRunner调用Oracle存储过程
为了测试这个存储过程,我遥了一圈去做这个事情,这里说一下我自己接受到任务和自己开始是怎么想的. 方法一: 一开始我想着可以使用C#直接去调用存储过程,然后用Loadrunner调用C#的dll去测试, ...
- MyBatis调用Oracle存储过程
MyBatis调用Oracle存储过程 1.无输入和输出参数的存储过程 2.带有输入和输出参数的存储过程 3.返回游标的存储过程 mybatis中的配置文件代码 <resultMap type= ...
- SQL 语句调用这个存储过程,生成顺序编码
一直很讨厌存储过程,没想到今天帮了我大忙啊,或许会因为今天让我慢慢喜欢上存储过程吧,不多说了,切入正题 在使用数据库的时候,难免要在使用过程中进行删除的操作,如果是使用int类型的字段,令其自增长,这 ...
- java代码调用oracle存储过程
一.简介 与调用mysql存储过程类型过程都是如下 1.创建连接 Connection conn = DriverManager.getConnection(url, user, password); ...
- 调用MYSQL存储过程实例
PHP调用MYSQL存储过程实例 http://blog.csdn.net/ewing333/article/details/5906887 http://www.cnblogs.com/kkchen ...
- (转载)delphi 中如何调用sql 存储过程
delphi 中如何调用sql 存储过程 使用TADOStoredProc组件,可以,给你举个例子好了 with ADOStoredProc1 do begin Close; Parameters.C ...
- Jfinal调用Orcale存储过程
因为项目需要,最近一直在学习Orcale存储过程,但发现在网上很少有人写Jave中Jfinal调用Orcale存储过程的文章,即使有也是几年前的,很多都不能用,今天给大家分享一段Jfinal调用Orc ...
- Dynamics CRM - 使用 C# Plugin 调用 SQL 存储过程
有时候,在 Dynamics CRM Plugin 中通过 linq 查询数据会比较慢,可以通过采用在 C# plugin 中直接调用数据库存储过程的方式来提高效率,具体过程如下: 1.新建一个存储过 ...
随机推荐
- Ubuntu系统里下载安装配置redis-2.2.13.tar.gz
不多说,直接上干货! Redis是一个NoSQL数据库,在数据需要频繁更新,并且数据的访问热点范围比较广的应用场景下,Redis的效率很不错. 下面介绍Redis的安装过程,如下面的步骤所示. 第一步 ...
- 使用jxl读取excel内容,并转换成Json,用于Datagrid
一.上传excel文件,得到InputStream,由InputStream得到Jxl中的Workbook,取出内容,存到二维数组中. 1.使用 Jquery Uploadify 插件(http:// ...
- Oracle11gExpress和PL/SQL Developer安装
Oracle11g为64位版本,PL/SQL Developer为32位版本 1.安装64为Oracle数据库/ 适用于 Microsoft Windows (x64) 的 Oracle Databa ...
- JS获取鼠标位置,兼容IE FF
由于Firefox和IE等浏览器之间对js解释的方式不一样,firefox下面获取鼠标位置不能够直接使用clientX来获取.网上说的一般都是触发mousemove事件才行.我这里有两段代码,思路都一 ...
- Spring mvc框架下使用kaptcha生成验证码
1.下载jar包并导入. kaptcha-2.3.2.jar 2.spring 配置文件 applicationContext.xml. <bean id="captchaProduc ...
- DevExpress 14.2 批量汉化
1.下载DevExpress_.NET_Localization_Resources_14.2汉化包 2.解压后将zh-CN或zh-CHS复制到安装目录如D:\Program Files (x86)\ ...
- 深入理解java线程池—ThreadPoolExecutor
几句闲扯:首先,我想说java的线程池真的是很绕,以前一直都感觉新建几个线程一直不退出到底是怎么实现的,也就有了后来学习ThreadPoolExecutor源码.学习源码的过程中,最恶心的其实就是几种 ...
- html-框架标签的使用
<frameset> - rows:按照行进行划分 ** <frameset rows="80,*"> - cols:按照列进行划分 ** <fram ...
- IoT Architecture
- 【Linux】 静态函数库设计
一.外部函数来源-- 函数库&系统调用 二.函数库分类 静态函数库 --多份拷贝 动态函数库 --单份拷贝 区别 链接方式区别 三.函数库存放位置 Linux应用程序使用的主要函数库均存放于/ ...