科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道Java、XML与数据库编程实践

Java、XML与数据库编程实践

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

  在开始学习XML和数据库编程时,大家都对一大堆的文档和资料,无从入手。作者在工作中,正好要用到了这些,就手头的一个程序进行整理。其功能很简单,得用java语言,从access数据库中,把一些数据导入到SQL数据库中。

作者:中国IT实验室 来源:中国IT实验室 2007年9月22日

关键字:

  • 评论
  • 分享微博
  • 分享邮件

在本页阅读全文(共4页)


  文件DbInput.java则是真正的数据拷贝部分:
  
  import java.sql.*;
  
  public class DbInput
  
  {
  
    Connection src=null;
  
    Connection dest=null;
  
    Connection connformax=null;
  
    ConnPara srcPara;
  
    ConnPara destPara;
  
    public DbInput(){}
  
    
  
    public void dbInit()
  
    {
  
      DbXmlParser xmlparser=new DbXmlParser("dbs.xml");
  
      srcPara=xmlparser.getSource();
  
      destPara=xmlparser.getDest();
  
      try {
  
        Class.forName("sun.jdbc.odbc.JdbcOdbcDriver" );
  
        Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver");
  
        src = DriverManager.getConnection( srcPara.getUrl(), srcPara.getUsername(),srcPara.getPassword());
  
        dest =DriverManager.getConnection( destPara.getUrl(), destPara.getUsername(),destPara.getPassword());
  
        connformax= DriverManager.getConnection( destPara.getUrl(), destPara.getUsername(),destPara.getPassword());
  
      }
  
      //捕获加载驱动程序异常
  
      catch ( ClassNotFoundException cnfex ) {
  
        System.err.println( "装载 JDBC/ODBC 驱动程序失败。" );
  
        cnfex.printStackTrace();
  
        System.exit( 1 ); // terminate program
  
      } catch ( SQLException ex )
  
      {
  
        System.err.println( "连接失败" );
  
        ex.printStackTrace();
  
        System.exit( 1 ); // terminate program
  
      }     
  
    }
  
    public void copyproduct()
  
    {
  
      Statement st=null;
  
      ResultSet rset=null;
  
      String sqlstr;
  
      try {
  
        //执行SQL语句
  
        String query = "select * from production";
  
        st = src.createStatement();
  
        rset = st.executeQuery(query);     
  
        int pid,ljid,cid,ciid;
  
        while(rset.next())
  
        {
  
        String pnumber=rset.getString(1);
  
        String ljnumber=rset.getString(2);
  
        String cnumber=rset.getString(3);
  
        //插入到产品表
  
        pid=getIdfromNumber("project","number",pnumber);
  
        if(pid==0) //插入一条新记录
  
        {
  
          pid=getMax("project");//System.out.println(pid);
  
          sqlstr="Insert into project(id,number) values("+pid+",'"+pnumber+"')";
  
          execute(destPara,sqlstr);
  
        }     
  
        //插入到零件表
  
        ljid=getIdfromNumber("product","number",ljnumber);
  
        if(ljid==0) //插入一条新记录
  
        {
  
          ljid=getMax("product");
  
          sqlstr="Insert into product(id,pid,number) values("+ljid+","+pid+",'"+ljnumber+"')";
  
          execute(destPara,sqlstr);
  
        }     
  
        //插入工具表
  
        cid=getIdfromNumber("componenttype","number",cnumber);
  
        if(cid==0) //插入一条新记录
  
        {
  
          cid=getMax("componenttype");
  
          sqlstr="Insert into componenttype(id,aid,number) values("+cid+","+ljid+",'"+cnumber+"')";
  
          execute(destPara,sqlstr);
  
        }          
  
        }
  
      }
  
      catch ( SQLException sqlex ) {
  
        sqlex.printStackTrace();
  
      }   
  
    }

查看本文来源

    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章