• java excel导入oracle数据库


    参考:http://blog.csdn.net/qq_40576686/article/details/78618846,只做了一些小的修改。

    java把excel数据写入Oracle数据库,此处需要引入两个文件:ojdbc14.jar,jxl-2.6.10.jar,,excel文件内容与数据库内表字段对应,此处注意:(excel版本太高了 报错:Exception in thread "main" jxl.read.biff.BiffException: Unable to recognize,把文件保存成excel 97-2003即可)

    另外,excel中数据量有些多时,代码循环体内,不能带有数据库连接的创建及关闭,否则会导致连接错误:

    Listener refused the connection with the follow
    ing error:
    ORA-12519, TNS:no appropriate service handler found
    The Connection descriptor used by the client was:


    /**
    * excel数据导入到oracle
    * @author
    *
    */
    public class excelToOracle {
    public static void main(String[] args) throws Exception {

    excelToOracle in = new excelToOracle();

    // excel文件路径,数据库表名
    in.insert("D:/BM_SPFL_TEST.xls","BM_SPFL");

    }

    /**
    *
    * @param path
    * 要解析的excel文件路径
    * @param dataTable
    * 要写入到数据库中的表名
    * @throws BiffException
    * @throws IOException
    * @throws SQLException
    */
    public void insert(String path,String dataTable) throws Exception{

    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();
    // 获取数据库连接,避免循环体内多次调用、关闭连接,导致报数据库连接错误
    jdbc.getConnection();


    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();
    }

    }


    /**
    * Oracle数据库连接
    *
    * @author
    */
    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:@192.168.201.106:1521:orcl";

    /** Oracle数据库连接驱动 */
    private final static String DB_DRIVER = "oracle.jdbc.driver.OracleDriver";

    /** 数据库用户名 */
    private final static String DB_USERNAME = "xnw_dev";

    /** 数据库密码 */
    private final static String DB_PASSWORD = "xnw_dev";

    /**
    * 获取数据库连接
    *
    * @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 {
    // 此处及finally内,不进行建立数据库连接及关闭,避免被循环调用时,多次创建占用数据库连接导致报错
    //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();
    }
    }

    }

  • 相关阅读:
    关于ping github.com超时的解决办法
    git使用过程中的若干问题笔记
    PAT甲级1017题解——模拟排序
    第七章4
    第七章3
    第七章2
    第七章1
    第六章4
    第六章3
    第六章2
  • 原文地址:https://www.cnblogs.com/pp153/p/8117577.html
Copyright © 2020-2023  润新知