设为首页 收藏本站
查看: 860|回复: 0

[经验分享] PL/SQL和Oracle对象

[复制链接]

尚未签到

发表于 2018-9-6 12:10:45 | 显示全部楼层 |阅读模式
  

  
package com.my.utils;
  

  
import java.sql.CallableStatement;
  
import java.sql.Connection;
  
import java.sql.ResultSet;
  
import java.sql.SQLException;
  

  
import org.junit.Test;
  

  
import oracle.jdbc.OracleTypes;
  
import oracle.jdbc.driver.OracleCallableStatement;
  
import oracle.jdbc.oracore.OracleType;
  

  
public class TestOracle {
  

  
/*
  
* 存储过程(out参数)
  
*
  
查询某个员工的姓名 月薪 职位
  
思考:
  
1. 查询某个员工的所有信息 ---> out参数太多
  
2. 查询某个部门中的所有员工信息  ---> 返回集合
  
*
  
create or replace procedure queryEmpInformation(eno in number,
  
            pename out varchar2,
  
            psal   out number,
  
            pjob   out varchar2)
  
as
  
begin
  
   select ename,sal,job into pename,psal,pjob from emp where empno=eno;
  
end;
  
/
  
* */
  
@Test
  
public void testProcedure(){
  
String sql="{call queryEmpInformation(?,?,?,?)}";
  

  
Connection conn=null;
  
CallableStatement call=null;
  

  
try {
  
conn=JDBCUtils.getConnection();
  
call=conn.prepareCall(sql);
  

  
call.setInt(1, 7839);
  
call.registerOutParameter(2, OracleTypes.VARCHAR);
  
call.registerOutParameter(3, OracleTypes.NUMBER);
  
call.registerOutParameter(4, OracleTypes.VARCHAR);
  

  
call.execute();
  
String name=call.getString(2);
  
double sal=call.getDouble(3);
  
String job=call.getString(4);
  
System.out.println(name+"\t"+sal+"\t"+job);
  
} catch (SQLException e) {
  
e.printStackTrace();
  
}finally {
  
JDBCUtils.release(conn, call, null);
  
}
  
}
  

  
/*
  
* 存储函数
  
*
  
* --查询某个员工的年收入
  
create or replace function queryEmpIncome(eno in number)
  
return number
  
as
  
    --月薪和奖金
  
    psal emp.sal%type;
  
    pcomm emp.comm%type;
  
begin
  
    --得到月薪和奖金
  
    select sal,comm into psal,pcomm from emp where empno=eno;
  
    --返回年收入
  
    return psal*12+nvl(pcomm,0);
  
end;
  
/
  
* */
  

  
@Test
  
public void testfunction(){
  
String sql="{?=call queryEmpIncome(?)}";
  

  
Connection conn=null;
  
CallableStatement call=null;
  

  
try {
  
conn=JDBCUtils.getConnection();
  
call=conn.prepareCall(sql);
  

  
call.registerOutParameter(1, OracleTypes.NUMBER);
  

  
call.setInt(2,7839);
  
call.execute();
  
double income=call.getDouble(1);
  
System.out.println(income);
  
} catch (SQLException e) {
  
e.printStackTrace();
  
}finally {
  
JDBCUtils.release(conn, call, null);
  
}
  
}
  

  
/*
  
在out中使用光标
  
2. 查询某个部门中的所有员工信息  ---> 返回集合
  
包头
  
CREATE OR REPLACE PACKAGE MYPACKAGE AS
  
  type empcursor is ref cursor;
  
  procedure queryEmpList(dno in number,empList out empcursor);
  
END MYPACKAGE;
  
包体
  
CREATE OR REPLACE PACKAGE BODY MYPACKAGE AS
  
  procedure queryEmpList(dno in number,empList out empcursor) AS
  
  BEGIN
  
    open empList for select * from emp where deptno=dno;
  
  END queryEmpList;
  
END MYPACKAGE;
  
*/
  

  
@Test
  
public void testCursor(){
  
String sql="{call MYPACKAGE.QUERYEMPLIST(?,?)}";
  

  
Connection conn=null;
  
CallableStatement call=null;
  
ResultSet rs=null;
  
try {
  
conn=JDBCUtils.getConnection();
  
call=conn.prepareCall(sql);
  

  
call.setInt(1, 10);
  

  
call.registerOutParameter(2,OracleTypes.CURSOR);
  

  
call.execute();
  

  
rs=((OracleCallableStatement)call).getCursor(2);
  

  
while(rs.next()){
  
String name=rs.getString("ename");
  
double sal=rs.getDouble("sal");
  
String job=rs.getString("job");
  
System.out.println(name+"\t"+sal+"\t"+job);;
  
}
  

  

  
} catch (SQLException e) {
  
e.printStackTrace();
  
}finally {
  
JDBCUtils.release(conn, call, null);
  
}
  
}
  

  
}



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-564051-1-1.html 上篇帖子: Oracle——redo+undo总结 下篇帖子: Linux系统Oracle12.2 RAC集群实施维护_Oracle数据库12cR2(项目实战之五)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表