如何在java环境下执行sql脚本文件

     有时候,在实际应用中,我们导出生成一个脚本文件,这个脚本文件的内容可能是一些简单的insert或update语句。那么如何在java环境中执行这个脚本文件来实现一些sql的操作呢?

     一:首先,在jsp部份需要提供一个由用户定位到这个sql文件的窗口,可以通过<input type="file"/>来实现,具体的代码如下:

<tr>

<td>数据文件</td>

<td>

<html:text property="DATA_FILE" size="40" readonly="true"/>

<INPUT TYPE="file" NAME="impData" style="display:none" >

              <input type="button" name="btnInput" value="浏 览" onClick="getFileName();" />

         </td>

     </tr>

     其中:

function getFileName(){

          //这里用fireEvent()不行。

          //$("impData").fireEvent("onclick");

          $("impData").click();

          $("DATA_FILE").value = $("impData").value;

     }

     二:在把数据文件的目录值($("DATA_FILE").value)传到servlet端的过程中,因为有可能会涉及到中文的目录,这时要注意的是字符传递编码的问题,处理如下:

在传到servlet前需要编码encodeURIComponent(encodeURIComponet()),如下:

     var data_file=encodeURIComponent(encodeURIComponent($("DATA_FILE").value));在servlet端到到的值需要解码java.net.URLDecoder.decode(request.getParameter(""),"UTF-8"),如下:

      String data_file =  java.net.URLDecoder.decode(request.getParameter("DATA_FILE"), "UTF-8");

     三:编码的问题解决后,在ejb端的主要任务就是在sqlplus的环境中执行这个脚本文件,如下:

         try {

              Runtime rt = Runtime.getRuntime();

              String sql = "sqlplus "+user_code+"/"+user_pwd + "@"+ orc_service + " @/""+ data_file+"/"";

              rt.exec(sql);

         }catch (Exception e) {

              e.printStackTrace();

         }

     其中,user_code,user_pwd和orc_service写在常量类里,类的代码如下:

     public final class Contants {

          public static final String USER_CODE = "eol";

          public static final String USER_PWD = "eol";

          public static final String ORC_SERVICE = "racdb";

}

 

讨论:

     以上的ejb的解决方案有个问题是:

     如果这个脚本文件里的sql语句有错误,用rt.exec(sql);这句方式并不会捕获到异常,而是像正确执行一样,没办法回滚。因为rt.exec(sql);句话是执行正常的,并没有出现异常,只是执行内部的sql语句的时候有错误发生。这种情况应该如何解决呢?

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值