JDBC操作调用Qracle中过程或函数取得数据

在java中可以通过直接向数据库传输SQL语言字符串的方式来调用数据库中的数据,但这样会有很多缺点,比如说容易被他人从网络注入SQL语句,传输数据量大影响效率之类的。

    所以一般的JAVA程序操作数据库的方式都是通过事先在数据库中用PL/SQL编程建立好我们需要操作的过程或者函数,然后由JAVA程序通过JDBC直接来调用数据库中的过程来达到我们的目的,这样他人就难以从网络悄悄的注入SQL语句来窃取我们数据库的数据了,并且传输的数据量也变小的,优化了效率。

    下面是用JDBC调用数据库中的过程和函数来达到获取和修改数据的目的的一个实例:

1.首先我们用scott用户登录,给它新建一个LOL表,再给表中插入一些数据

Sql代码   收藏代码
  1. --新建一个表  
  2. create table lol(heronum number(5),heroname varchar2(10),herotype varchar2(10));  

 

     (建立一个序列,来给表中的每一条数据一个连续的编号)

Java代码   收藏代码
  1. --新建一个序列()  
  2. create or replace sequence seq_lol  
  3. start with 1   --从0开始  
  4. increment by 1  --每次增加1  
  5. maxvalue 100  --最大值为100  
  6. nocycle      --不循环  
  7. nocache      --没有缓存(语句执行失败时不会增加)  

 

 

 

Sql代码   收藏代码
  1. <strong>--给表中插入数据  
  2. insert into lol values(seq_lol.nextval,'盖伦','肉盾');  
  3. insert into lol values(seq_lol.nextval,'赵信','近战');  
  4. insert into lol values(seq_lol.nextval,'易','近战');  
  5. insert into lol values(seq_lol.nextval,'提莫','射手');  
  6. insert into lol values(seq_lol.nextval,'瑞兹','法师');</strong>  

2.(修改数据)我们发现表中插入的第一条数据错了,盖伦应该是近战类型的,这里定义一个过程来通过输入一个heroname来修改这条数据的herotype.

Sql代码   收藏代码
  1. --通过输入一个英雄的名字,来修改他的类型  
  2. create or replace procedure pro_updateTypeByName(v_heroname varchar2,v_herotype varchar2) is  
  3.   
  4. begin  
  5.   update lol set herotype=v_herotype where heroname=v_heroname;  
  6. end;  

3.通过JDBC来调用数据库中的过程,修改名字为盖伦的英雄的类型.

    (1)首先在JAVA中写一个类用来获得连接数据库的连接对象(此处将这个类的构造方法私有化了,这样让外界只能通过调用它里面的静态方法来获得对象,然后再在这个取得对象的静态方法里作一系列判断,让程序的运行中只存在一个连接对象,这样就节约了程序的资源,优化了数据库与JAVA的连接效率).

Java代码   收藏代码
  1. /** 
  2.  * 连接数据库,获得数据库连接对象 
  3.  * @author yy 
  4.  * 
  5.  */  
  6. public class DBUtil {  
  7.     private static Connection conn;  
  8.     //将构造方法私有化,让这个类只能通过调用下面的静态方法来创建对象  
  9.     private DBUtil(){  
  10.           
  11.     }  
  12.     public static Connection getconn(){  
  13.         if(conn==null){  
  14.             try {  
  15.                 //装载驱动(此处先要在工程处引入外界的JDBC包)  
  16.                 Class.forName("oracle.jdbc.driver.OracleDriver");  
  17.                 String url = "jdbc:oracle:thin:@172.19.238.127:1521:ORCL";  
  18.                 //获得数据库连接  
  19.                 conn = DriverManager.getConnection(url, "scott""scott");  
  20.                 return conn;  
  21.             } catch (Exception e) {  
  22.                 e.printStackTrace();  
  23.             }  
  24.             return null;  
  25.         }  
  26.         return conn;  
  27.     }  
  28. }  

     (2).定义一个操作类,类中创建一个用来执行数据库中过程的方法.

Java代码   收藏代码
  1. public class EXEChw {  
  2.     /** 
  3.      * 通过名字修改类型 
  4.      * @param name 要修改英雄的名字 
  5.      * @param newtype 要修改成的类型 
  6.      */  
  7.     public void setTypeByName(String name,String newtype){  
  8.         try{  
  9.         //获得数据库连接对象  
  10.         Connection conn = DBUtil.getconn();  
  11.         //定义调用过程的SQL语句(此处的?是一个占位符,在编译了SQL语句之后再给它赋值,这样可以防止全能等式的BUG)  
  12.         String sql = "{call pro_updateTypeByName(?,?)}";  
  13.         //获得编译对象  
  14.         CallableStatement cstm = conn.prepareCall(sql);  
  15.         //给?赋值  
  16.         cstm.setString(1, name);  
  17.         cstm.setString(2, newtype);  
  18.         //执行过程  
  19.         cstm.execute();  
  20.         }catch(Exception e){  
  21.             e.printStackTrace();  
  22.         }  
  23.     }  
  24. }  

     (3).通过调用方法来执行数据库中的过程,修改数据库中的内容,将盖伦的类型改为近战

Java代码   收藏代码
  1. EXEChw eh = new EXEChw();  
  2. eh.setTypeByName("盖伦""近战");  

     (4).在数据库中查看lol表,看以上操作是否改变了盖伦的类型

Sql代码   收藏代码
  1. SQL> select * from lol;  
  2.    
  3. HERONUM HERONAME   HEROTYPE  
  4. ------- ---------- ----------  
  5.       1 盖伦       近战  
  6.       2 赵信       近战  
  7.       3 易         近战  
  8.       4 提莫       射手  
  9.       5 瑞兹       法师  
  10.    
  11. SQL>   

 3.(取得数据)我们要通过输入一个英雄的编号,取得这个英雄的所有信息

    (1).在数据库中创建这个过程.

Sql代码   收藏代码
  1. --通过输入一个英雄的编号,来获得这个英雄的所有信息  
  2. create or replace procedure pro_getAllByNum(v_heronum in number,v_heroname out varchar2,v_herotype out varchar2) is  
  3.   
  4. begin  
  5.   select heroname,herotype into v_heroname,v_herotype from lol where heronum=v_heronum;  
  6. end;  

    (2).在EXChw类中创建一个方法来通过JDBC调用这个过程,获得该编号英雄的名字和类型输出.

 

Java代码   收藏代码
  1. /** 
  2.  * 通过编号来获得名字和类型 
  3.  * @param num 依据的编号 
  4.  */  
  5. public void getNameTypeByNum(int num){  
  6.     try{  
  7.     //获得数据库连接对象  
  8.     Connection conn = DBUtil.getconn();  
  9.     //定义调用过程的SQL语句(此处的?是一个占位符,在编译了SQL语句之后再给它赋值,这样可以防止全能等式的BUG)  
  10.     String sql = "{call pro_getAllByNum(?,?,?)}";  
  11.     //获得编译对象  
  12.     CallableStatement cstm = conn.prepareCall(sql);  
  13.     //给第一个?赋值  
  14.     cstm.setInt(1, num);  
  15.     //给第二三个?注册输出的参数  
  16.     cstm.registerOutParameter(2, java.sql.Types.VARCHAR);  
  17.     cstm.registerOutParameter(3, java.sql.Types.VARCHAR);  
  18.     //执行过程  
  19.     cstm.execute();  
  20.     //获得输出的参数的值  
  21.     String name = cstm.getString(2);  
  22.     String type = cstm.getString(3);  
  23.     //输出  
  24.     System.out.println("名字:"+name+",类型:"+type);  
  25.     }catch(Exception e){  
  26.         e.printStackTrace();  
  27.     }  
  28. }  

     (3).JAVA中的输出为

Java代码   收藏代码
  1. 名字:易,类型:近战  

 4.显示lol表中的所有数据(游标的使用)

太晚了,明天写  ≡ ‘(*>﹏<*)′ ~

本文由上海java培训机构推荐阅读,更多精彩请浏览上海IT培训官网。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值