Java资源网

| JAVA基础 | 环境配置 | JDBC | 线程技术 | Socket编程 | JavaMail | JAVA与XML | 设计模式 | 技术新闻 | Java认证 | 程序人生 软件下载
| JSP&Servlet | Spring | Struts | Hibernate | JBuilder | Eclipse | WebService | EJB技术 | J2ME开发 | 应用服务器 | JXTA | Ajax
Articles search文章搜索
   关键字:
   类 别:
       
New download 最新下载
· [组件]HTML Parser 1.5
· [教程]WebSphere Studio应用教程
· [组件]JDom 1.0
· [工具]Junit3.8.1
· [教程]EJB编程及J2EE系统架构和设计
· [教程]EJB教程
· [教程]J2EE Tutorial中文版
· [教程]Java编程思想2(英文)
· [教程]java编程思想(完整版)
· [教程]Java网络编程
New articles 最新文章
· 设计移动 Web 服务
· 解析XML的时候完全忽略DTD
· 理解XML Schema XML Schema 初步
· 标签库的深入研究
· 提升JSP应用程序的七大绝招
· 如何使用JDOM对XML文件进行操作
· 处理XML字符串中特殊字符
· 利用Digester把XML转换成为Java对象
· 使用WebService 和RMI远程协作
· 使用Axis开发Web Service程序
Articles top 热门文章
· Eclipse基础--plugin插件安装(6644)
· eclipse+tomcat+lomboz的安装配置说明(4774)
· Java程序员就业前景(4584)
· Windows下JAVA环境变量的设置祥解(3788)
· Tomcat下JSP、Servlet和JavaBean环境的配置(3716)
· 使用links方式安装Eclipse插件(3698)
· 一个老程序员的心理话(3533)
· linux下jdk的安装与配置(3459)
· 初学者入门:Structs中基本配置入门(3334)
· Eclipse 运行命令行参数大全(3084)
您的位置:首页>>JDBC>>Excel导入数据库工具包
Excel导入数据库工具包
2005-08-25   来源:Java研究组织  作者:efly
设计目的 
使用该工具包,能够将MS Excel表格数据导入到具有相应结构的关系型数据库表格。通过扩展接口能对Excel表格的每一列或行的数据进行操作,剔除坏数据,修复或者替换特定单元的数据,从而实现了Excel数据自由导入具有外键关联或引用的表格。该工具包在导入数据的同时还能生成结构简单的Xml数据文件。

类结构

 
使用说明
扩展接口com.uncnet.dbexcel.Flopper,实现相应的方法
方法:String conversionOp(
        Connection connection,
        String arg,
        int index,
        Document doc,
        Element table,
        Element row)
        throws Exception;
描述:对Excel列的单元进行数据转换并操作数据库表格。
参数:Connection connection,数据库连接;
      String arg,Excel列单元的数据;
      int index,Excel表格列序号,从1开始;
      Document doc,UNC Xml的Document元素;
      Element table,UNC Xml的元素;
      Element row,UNC Xml的元素。
返回:经过从Excel Xml到UNC Xml转换的数据。
代码示例:
/**
     * @see com.uncnet.dbexcel.Flopper#conversionOp(Connection, String, int, Document, Element, Element)
     */
    public String conversionOp(
        Connection connection,
        String arg,
        int index,
        Document doc,
        Element table,
        Element row) {
        String text = null;
        if (arg == null)
            arg = "";
        try {
            if (connection == null)
                return "No Connection";
            stmt = connection.createStatement();
            if (col_num++ % COLUMNS == 0)
                ps_in = new String[COLUMNS + 1];

            switch (index) {
                case 1 :
                    {
                        text = arg;
                        ps_in[0] = arg;
                        break;
                    }
                case 8 :
                    {
                        text = arg;
                        ps_in[8] = findForDict(null, arg, stmt, 8);
                        break;
                    }
                case 10 :
                    {
                        text = arg;
                        if (!arg.equals(""))
                            ps_in[10] = arg.substring(1);
                        else
                            ps_in[10] = arg;
                        break;
                    }
                default :
                    {
                        text = arg;
                        ps_in[index] = arg;
                    }
            }
            if (col_num % COLUMNS == 0)
                isToCmt = true;
            else
                isToCmt = false;
            if (isToCmt) {
                pstmt = connection.prepareStatement(sqlscript);
                connection.setAutoCommit(false);
                row_num++;
                boolean isToExe = true;
                try {
                    Integer.parseInt(ps_in[0]);
                    Integer.parseInt(ps_in[1]);
                } catch (NumberFormatException nfe) {
                    isToExe = false;
                }
                StringTokenizer ster = null;
                Date date = null;
                int year, month, day;
                for (int i = 0; i < COLUMNS + 1; i++) {
                    if (i == 12 || i == 13) {
                        ster = new StringTokenizer(ps_in[i], "-");
                        year = Integer.parseInt(ster.nextToken());
                        month = Integer.parseInt(ster.nextToken());
                        day = Integer.parseInt(ster.nextToken());
                        date = new Date(year, month, day);
                        pstmt.setDate(i + 1, date);
                    } else
                        pstmt.setString(i + 1, ps_in[i]);
                    System.err.print(ps_in[i] + " ");
                }
                System.err.println();
                if (isToExe) {
                    pstmt.execute();
                    connection.commit();
                } else
                    System.err.print("Encountering null.");
                connection.setAutoCommit(true);
                if (pstmt != null)
                    pstmt.close();
            }
        } catch (Exception e) {
            e.printStackTrace(System.err);
        } finally {
            try {
                if (stmt != null)
                    stmt.close();
                if (isToCmt && pstmt != null)
                    pstmt.close();
            } catch (Exception e) {
                System.err.println(e);
            }
        }
        if (text == null) {
            table.removeChild(row);
        }

        return text;
    }

方法:void setParameter(String[] para);
描述:设置程序参数
参数:String[] para

方法:Connection getConnection();
描述:建立数据库连接
返回:数据库连接

方法:void closeConnection(Connection conn);
描述:关闭数据库连接
参数:Connection conn,数据库连接

方法:void beginConvert();
描述:开始转换前的操作

方法:void endOfConvert();
描述:转换完成后的操作

方法:void afterConnected(Connection conn);
描述:数据库建立连接后的操作

方法:void beforeClosed(Connection conn);
描述:关闭数据库连接前的操作

接口Flopper扩展类
类:com.uncnet.dbexcel.flopper.DBFlopper
描述:实现了数据库的连接与关闭和参数的设置

类:com.uncnet.dbexcel.flopper.DictFlopper
描述:字典类,实现了从文件查找字典表的对应数据

程序的执行
主程序入口:com.uncnet.dbexcel.TextController的main方法
调用参数:Excel Xml文件路径,输出UNC Xml文件路径,Flopper扩展类名字空间,其它扩展参数...
参数示例:
F:\work4\9-23\expert.xml F:\work4\9-23\_expert2.xml com.uncnet.dbexcel.flopper.YpzbExpertFp oracle.jdbc.driver.OracleDriver jdbc:oracle:thin:@127.0.0.1:1521:oracle scott tiger F:\work4\9-23\data\diploma.txt F:\work4\9-23\data\hospital.txt

附件
工具包
  --相关文章--
· 通过JDBC连接oracle数据库的十大技巧 (2007-04-13)
· 第一个JDBC程序 (2007-04-13)
· 符合oo惯例的表现层控制 (2007-04-13)
· 用hibernate对递归数据的操作 (2007-04-13)
· 煮酒论英雄nbsp;-nbsp;漫谈Java数据库存取技术 (2007-04-13)
· 利用weblogic的数据源作为hibernate的数据源的例子 (2007-04-13)

版权所有©2005-2006 JAVA资源网 渝ICP备05007591号 虚拟主机 | 关于我们 | 联系方式 | 广告业务 | 网站地图 | 友情链接