如何在java环境下执行sql脚本文件
来源:互联网 发布:面向对象高级编程 编辑:程序博客网 时间:2024/06/06 01:45
有时候,在实际应用中,我们导出生成一个脚本文件,这个脚本文件的内容可能是一些简单的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语句的时候有错误发生。这种情况应该如何解决呢?
- 如何在java环境下执行sql脚本文件
- MySql下如何执行sql脚本文件
- Windows环境下如何在cmd(命令执行窗口)运行python脚本文件。
- Java 执行 SQL 脚本文件
- Java 执行 SQL 脚本文件
- Java执行SQL脚本文件
- 在windows环境下批量执行ORACLE的*.sql文件
- 【转】mysql下如何执行sql脚本
- mysql下如何执行sql脚本
- mysql下如何执行sql脚本
- mysql下如何执行sql脚本
- mysql下如何执行sql脚本
- mysql下如何执行sql脚本
- mysql下如何执行sql脚本
- mysql下如何执行sql脚本
- mysql下如何执行sql脚本
- mysql下如何执行sql脚本
- mysql下如何执行sql脚本
- CDatabase类的使用及dbf文件的访问
- sql语句中几个关键字的意思及用法
- 巧用端口映射 不通过网关开放任意内网
- 2008金山暑期实习在线考试(2008-06-14)小记
- C语言宏定义技巧
- 如何在java环境下执行sql脚本文件
- 创新工作
- 小心 SQL语句SELECT TOP 的用法
- ASM的学习笔记
- flex中socket的使用
- new和malloc操作符的区别
- 关于我对Mozilla的研究
- 自动化测试框架设计指南
- how to config when use hibernate+sqlserver2005