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数据库的对应表 连接想要导入的数据库 ,然 ...
随机推荐
- wamp开机自启动
其实非常简单!打开服务管理,把以下两个服务,由手动(默认状态)改为自动即可: wampapache wampmysqld
- GIT文件的三种状态
对于任何一个文件,在 Git 内都只有三种状态:已提交(committed),已修改(modified)和已暂存(staged).已提交表示该文件已经被安全地保存在本地数据库 中了:已修改表示修改了某 ...
- Javascript闭包——懂不懂由你,反正我是懂了
摘要:“如果你不能向一个六岁的孩子解释清楚,那么其实你自己根本就没弄懂.”好吧,我试着向一个27岁的朋友就是JS闭包(JavaScript closure)却彻底失败了. 越来越觉得国内没有教书育人的 ...
- AngularJs之ng-repeat的用法
可参考文章:http://blog.csdn.net/renfufei/article/details/43061877 ng-repeat信息展示的核心: [1]异步读取数据源 works,见代码一 ...
- [转载]Python-第三方库requests详解
Requests 是用Python语言编写,基于 urllib,采用 Apache2 Licensed 开源协议的 HTTP 库.它比 urllib 更加方便,可以节约我们大量的工作,完全满足 HTT ...
- Linux下Apache配置SSL支持https
参考:http://www.thinksaas.cn/group/topic/280017/ 生成证书过程如下 Step :生成服务器密钥: mkdir -p /etc/pki/test cd /et ...
- cat -n与nl的区别
cat -n filename:空行也算一行 nl filename:空行不算一行
- php如何妩媚地生成执行的sql语句
会不会碰到这样一种情况呢?每次获取数据将数据和历史版本都有一定的差别,然而用ThinkPHP的addAll()函数,却会将已有的数据删掉再重新写入.这明显不是我们想要的.但自己写sql每次几十个字段也 ...
- lftp使用普通ftp模式登录
set ftp:use-feat no set ftp:passive-mode yes set ftp:ssl-protect-data no set ssl:verify-certificate ...
- 16. javacript高级程序设计-HTML5脚本编程
1. HTML5脚本编程 l 跨文档消息传递API能够让我们在不降低同源策略安全性的前提下,在来至不同的域的文档间传递消息 l 原生拖放功能可以方便的指定某个元素是否可以拖动,并在放置时做出响应.还可 ...