Java代码实现excel数据导入到Oracle
1.首先需要两个jar包jxl.jar,ojdbc.jar(注意版本,版本不合适会报版本错误)
2.代码:

- import java.io.File;
- import java.io.FileInputStream;
- import java.io.IOException;
- import java.io.InputStream;
- import jxl.Cell;
- import jxl.Sheet;
- import jxl.Workbook;
- import jxl.read.biff.BiffException;
- /**
- * excel数据导入到oracle
- * @author sh
- * 2010-05-11
- */
- public class InsertData {
- public static void main(String[] args) throws Exception {
- InsertData in = new InsertData();
- in.insert(“F:/myJob/hah.xls”,“information”);
- }
- /**
- *
- * @param path
- * 要解析的excel文件路径
- * @param dataTable
- * 要写入到数据库中的表名
- * @throws BiffException
- * @throws IOException
- */
- public void insert(String path,String dataTable) throws BiffException, IOException {
- File file = new File(path);
- // 创建新的Excel 工作簿
- Workbook rwb = null;
- rwb = Workbook.getWorkbook(file);
- // 得到工作簿中的第一个表索引即为excel下的sheet1,sheet2,sheet3…
- Sheet sheet = rwb.getSheets()[0];
- int rsColumns = sheet.getColumns();// 列数
- int rsRows = sheet.getRows();// 行数
- String simNumber = “” ;//每个单元格中的数据
- DBUtils jdbc=new DBUtils();
- String str=“”;//拼接要插入的列
- for (int j = 0; j <rsColumns; j++) {
- Cell cell = sheet.getCell(j, 0);
- simNumber = cell.getContents();
- if(j==rsColumns-1){
- str += simNumber ;
- }else{
- str += simNumber+“,”;
- }
- }
- for (int i = 1; i < rsRows; i++) {
- String sql = “insert into “+dataTable+“(“+str+“) values(“;//拼接sql
- System.out.println(str);
- for (int j = 0; j < rsColumns; j++) {
- Cell cell = sheet.getCell(j, i);
- simNumber = cell.getContents();
- if(j==rsColumns-1){
- sql += “‘”+ simNumber+“‘” ;
- }else{
- sql +=“‘”+ simNumber+“‘,”;
- }
- }
- sql += ” )”;
- jdbc.executeUpdate(sql);//执行sql
- }
- jdbc.closeStmt();
- jdbc.closeConnection();
- }
- }
Util类
- import java.sql.Connection;
- import java.sql.DriverManager;
- import java.sql.ResultSet;
- import java.sql.SQLException;
- import java.sql.Statement;
- /**
- * Oracle数据库连接
- *
- * @author sh 2010-05-11
- */
- public class DBUtils {
- private Connection conn = null;
- private Statement stmt = null;
- private ResultSet rs = null;
- /** Oracle数据库连接 URL */
- private final static String DB_URL = “jdbc:oracle:thin:@localhost:1521:XE”;
- /** Oracle数据库连接驱动 */
- private final static String DB_DRIVER = “oracle.jdbc.driver.OracleDriver”;
- /** 数据库用户名 */
- private final static String DB_USERNAME = “test”;
- /** 数据库密码 */
- private final static String DB_PASSWORD = “test”;
- /**
- * 获取数据库连接
- *
- * @return
- */
- public Connection getConnection() {
- /** 声明Connection连接对象 */
- Connection conn = null;
- try {
- /** 使用 Class.forName()方法自动创建这个驱动程序的实例且自动调用DriverManager来注册它 */
- Class.forName(DB_DRIVER);
- /** 通过 DriverManager的getConnection()方法获取数据库连接 */
- conn = DriverManager
- .getConnection(DB_URL, DB_USERNAME, DB_PASSWORD);
- stmt = conn.createStatement();
- } catch (Exception ex) {
- ex.printStackTrace();
- }
- return conn;
- }
- /**
- * 查询数据部分
- *
- * @return ResultSet
- */
- public ResultSet executeQuery(String sqlStr) {
- if (sqlStr == null || sqlStr.length() == 0)
- return null;
- try {
- this.getConnection();
- rs = stmt.executeQuery(sqlStr);
- return rs;
- } catch (SQLException ex) {
- ex.printStackTrace();
- return null;
- }
- }
- /**
- * 更新数据部分
- *
- * @return 更新是否成功
- */
- public boolean executeUpdate(String sqlStr) {
- if (sqlStr == null || sqlStr.length() == 0)
- return false;
- try {
- this.getConnection();
- stmt.executeUpdate(sqlStr);
- return true;
- } catch (SQLException ex) {
- ex.printStackTrace();
- return false;
- } finally {
- try {
- if (stmt != null) {
- stmt.close();
- }
- } catch (SQLException e) {
- e.printStackTrace();
- }
- try {
- if (conn != null) {
- conn.close();
- }
- } catch (SQLException e) {
- e.printStackTrace();
- }
- }
- }
- public void closeStmt() {
- try {
- if (stmt != null) {
- stmt.close();
- }
- } catch (Exception e) {
- e.printStackTrace();
- }
- }
- /**
- * 关闭数据库连接
- *
- * @param connect
- */
- public void closeConnection() {
- try {
- if (conn != null) {
- /** 判断当前连接连接对象如果没有被关闭就调用关闭方法 */
- if (!conn.isClosed()) {
- conn.close();
- }
- }
- } catch (Exception ex) {
- ex.printStackTrace();
- }
- }
- }
Java代码实现excel数据导入到Oracle的更多相关文章
- Access中一句查询代码实现Excel数据导入导出
摘 要:用一句查询代码,写到vba中实现Excel数据导入导出,也可把引号中的SQL语句直接放到查询分析器中执行正 文: 导入数据(导入数据时第一行必须是字段名): DoCmd.RunSQL &quo ...
- Excel数据导入到oracle
打开pl/sql,如图所示界面,点击菜单栏中的T00LS ODBC Imtorper,打开ODBC Importer选项框 在Data fromODBC页中选择需要导入的文件的格式 ...
- Java:将Excel数据导入到数据库(一眼就看会)
所用Jar包 1. sqljdbc4.jar 连接数据库的Jar包(根据数据库的不同进行选择,我用的SqlServer2008) 2.Jxl.jar 访问Excel的Jar包 注意:支持以.xls结尾 ...
- 用代码将Excel数据导入Sql Server
这里直接用小例子说明. 1.打开VS2010—>文件—>新建—>网站,选择ASP.NET空网站并设置存放路径以创建空网站.(我这里路径设置为D:\excelEduceToSql) 2 ...
- 代码执行批量Excel数据导入Oracle数据库
由于基于Oracle数据库上做开发,因此常常会需要把大量的Excel数据导入到Oracle数据库中,其实如果从事SqlServer数据库的开发,那么思路也是一样的,本文主要介绍如何导入Excel数据进 ...
- 批量Excel数据导入Oracle数据库
由于一直基于Oracle数据库上做开发,因此常常会需要把大量的Excel数据导入到Oracle数据库中,其实如果从事SqlServer数据库的开发,那么思路也是一样的,本文主要介绍如何导入Excel数 ...
- java实现EXCEL数据导入到数据库中的格式问题的解决
之前作为项目甲方,加之java接触不多,在java web开发方面都是打下手的份. 对于EXCEL数据导入到数据库这个问题一直老是出现格式原因而导入失败也是未免惆怅,开发团队也是只说回去检查一下格式. ...
- kettle将Excel数据导入oracle
导读 Excel数据导入Oracle数据库的方法: 1.使用PL SQL 工具附带的功能,效率比较低 可参考这篇文章的介绍:http://www.2cto.com/database/201212/17 ...
- 利用TOAD实现把EXCEL数据导入oracle数据库
利用TOAD实现把EXCEL数据导入oracle数据库 工具: Toad11.7z(百度搜索,直接下载) 1.将Excel文件中某些字段导入到Oracle数据库的对应表 连接想要导入的数据库 ,然 ...
随机推荐
- 2016年10月30日--JavaScript语法
1.基本数据类型:字符串.小数.整数.日期时间.布尔型等. 2.变量:[var]定义变量:var a:所有变量定义都用var定义,var是通用的可变类型. 3.类型转换:转为整数:parseInt() ...
- good luck
ACM大法好,明天求轻虐,水一波~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
- java去除字符串中的空格、回车、换行符、制表符
import java.util.regex.Matcher; import java.util.regex.Pattern; /** * @author chzeze * 2016-11-07 */ ...
- django缓存
由于Django是动态网站,所有每次请求均会去数据进行相应的操作,当程序访问量大时,耗时必然会更加明显,最简单解决方式是使用:缓存,缓存将一个某个views的返回值保存至内存或者memcache中,5 ...
- Java web中为什么要用Service接口和DAO接口?
面向接口:依赖倒转原理----使用service接口的原因是为了让表示层不依赖于业务层的具体实现,使用dao接口的原理也是如此,而且便于spring ioc容器,当修改dao层,时不需要修改servi ...
- Intellij IDEA使用总结
查询快捷键CTRL+N 查找类CTRL+SHIFT+N 查找文件CTRL+SHIFT+ALT+N 查 找类中的方法或变量CIRL+B 找变量的来源CTRL+ALT+B 找所有的子类CTRL ...
- Android Service1
一.Service的种类 按运行地点分类: 类别 区别 优点 缺点 应用 本地服务(Local) 该服务依附在主进程上, 服务依附在主进程上而不是独立的进程,这样在一定程度上节约了资源,另外L ...
- 更换CentOS7的下载源为阿里云
安装epel rpm -ivh http://mirrors.ustc.edu.cn/fedora/epel/7/x86_64/e/epel-release-7-7.noarch.rpm 1.备份 m ...
- ODATA 云驱动 http://www.cdata.com/cloud/
ODATA 云驱动 http://www.cdata.com/cloud/ 目前支持:ORACLE.MS SQL . MYSQL. -------------- rssbus ht ...
- FFPlay-noConsole-ver-20160409-snapshot
ESC 退出 0 进度条开关 1 屏幕原始大小 2 屏幕1/2大小 3 屏幕1/3大小 4 屏幕1/4大小 S 下一帧 [ -2秒 ] +2秒 ; -1秒 ' +1秒 下一个帧 -> -5秒 F ...