記錄一次從一個(gè)數(shù)據(jù)庫取數(shù)據(jù)存入到另一個(gè)數(shù)據(jù)庫中的操作過程

項(xiàng)目開發(fā)過程中 服務(wù)器出現(xiàn)了一些問題 很多的程序都不能用了 其中就有一個(gè)功能需要從一個(gè)sql server的數(shù)據(jù)庫中取數(shù)據(jù) 再錄入到oracle的庫中 過程中也出現(xiàn)了一些小問題 記錄一下

  1. 因?yàn)槭菍?duì)兩個(gè)不同的數(shù)據(jù)庫進(jìn)行操作 所以先要將兩個(gè)庫的jar包引入扼褪,需要注意jdk1.8需要使用sqljdbc4.jar,使用sqljdbc.jar會(huì)報(bào)錯(cuò)建峭。


    image.png
  2. 創(chuàng)建連接類DB2

import java.sql.*;


public class DB2 {
    protected final String URL2="jdbc:sqlserver://172.xx.xxx.xx:xxxx;DatabaseName=xxxx";
    protected final String URL="jdbc:oracle:thin:@xxx.xx.xxx.xx:1521:ORCL";
    protected final String USER="xxxx";
    protected final String USER2="xx";
    protected final String USER3="xx";
    protected final String PWD="xxxx";
    protected final String PWD2="xxxxx";
    protected final String PWD3="xxxx";
    protected Connection conn;
    protected PreparedStatement ps;
    protected ResultSet rs;

    public Connection getconn(){
        try {
//          Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
            Class.forName("oracle.jdbc.driver.OracleDriver");
            conn=DriverManager.getConnection(URL,USER,PWD);
        } catch (ClassNotFoundException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (SQLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        return conn;
    }
    public void getconn2(){
        try {
            Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
            conn=DriverManager.getConnection(URL2,USER2,PWD2);
        } catch (ClassNotFoundException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (SQLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }
    public void getconn3(){
        try {
//          Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
            Class.forName("oracle.jdbc.driver.OracleDriver");
            conn=DriverManager.getConnection(URL,USER3,PWD3);
        } catch (ClassNotFoundException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (SQLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }
    public void close(){
        try {
            if(rs!=null){
                rs.close();
            }
            if(ps!=null){
                ps.close();
            }
            if(conn!=null){
                conn.close();
            }
        } catch (SQLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }
    
}

其中把自己對(duì)應(yīng)的數(shù)據(jù)庫信息錄入就可以 可以看到第一個(gè)getconn方法是有返回值的呼伸。是因?yàn)橄虢oinsert方法添加上事務(wù)旅赢。后邊會(huì)具體說。

  1. 然后新建了一個(gè)任務(wù)類
import java.sql.Connection;
import java.sql.SQLException;
import java.text.DecimalFormat;
import java.text.SimpleDateFormat;
import java.util.Timer;
import java.util.TimerTask;

/**
 * Created with IntelliJ IDEA.
 * User: employeeeee
 * Date: 2019/12/16
 * Time: 11:13
 * Description: No Description
 */
public class Task {

    SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
    public void delete(){
        DB2 db=new DB2();
        db.getconn();
        String sql="delete from  t_realdata where systype=7";
        try{
            db.ps=db.conn.prepareStatement(sql);
            db.ps.executeUpdate();
        }catch(SQLException e){
            e.printStackTrace();
        }
        db.close();
    }

    public void seletAllWellVC(DB2 db2) {
        int count = 6000;
        DecimalFormat fg = new DecimalFormat("#,###,00");
        DB2 db = new DB2();
        db.getconn2();
        String sql = "select t.id,t.Point_name,t.value,t.Date_,zhsw.dbo.fun_getPY(t.Point_code) as Point_code from zhsw.dbo.t_data_huaxu t where point_name like '%*_%' ESCAPE '*' and point_name like '%井%電壓'\n" +
                "union all\n" +
                "select t.id,t.Point_name,t.value,t.Date_,zhsw.dbo.fun_getPY(t.Point_code) as Point_code  from zhsw.dbo.t_data_huaxu t where point_name like '%*_%' ESCAPE '*' and point_name like '%井%電流'";
        try {
            db.ps = db.conn.prepareStatement(sql);
            db.rs = db.ps.executeQuery();
            while (db.rs.next()) {
                count++;
                String code = db.rs.getString("Point_code");
                String datatime = db.rs.getString("Date_");
                datatime = datatime.substring(0, 19);
                double flow = db.rs.getDouble("value");
                insert(count,code,datatime,flow,db2);
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }
        db.close();
    }

   public void insert(Integer count,String code,String datatime,double flow,DB2 db){
       String sqls="insert into t_realdata(ID,POINTCODE,VALUE,INSERTTIME,SYSTYPE) values(?,?,?,TO_DATE(?,'YYYY-MM-DD HH24:MI:SS'),7)";
       try{
           db.ps=db.conn.prepareStatement(sqls);
           db.ps.setInt(1,count);
           db.ps.setString(2,code);
           db.ps.setString(3,flow+"");
           db.ps.setString(4,datatime);
           db.ps.executeUpdate();
          //如果不加會(huì)導(dǎo)致游標(biāo)報(bào)錯(cuò)
           db.ps.close();
       }catch(SQLException e){
           e.printStackTrace();
       }
    }

    public Task(){
        Timer timer = new Timer();
        DB2 db=new DB2();
        Connection connection = db.getconn();
        try {
            connection.setAutoCommit(false);
            int delay = 1000;//ms
            // 一秒一運(yùn)行
            int period = 1000*60;//ms
            timer.schedule(new TimerTask() {
                int i = 1;
                public void run() {
                    delete();
                    seletAllWellVC(db);
                    try {
                        //事務(wù)提交
                        connection.commit();
                    } catch (SQLException e) {
                        e.printStackTrace();
                    }
                    i++;
                    System.out.println(i);
                }
            }, delay, period);
        } catch (SQLException e) {
            try {
                connection.rollback();
            } catch (SQLException e1) {
                e1.printStackTrace();
            }
            e.printStackTrace();
        }

    }
}

只寫了兩個(gè)方法,一個(gè)是查詢方法蜈亩,一個(gè)是存儲(chǔ)的方法。
存儲(chǔ)的方法還是有點(diǎn)問題的前翎,因?yàn)榘裪nsert寫到了循環(huán)的方法中稚配。如果不在insert的方法之后添加一個(gè)ps的close的話就會(huì)出現(xiàn)游標(biāo)的報(bào)錯(cuò)。
而且最開始的時(shí)候沒有添加事務(wù) 會(huì)導(dǎo)致數(shù)據(jù)沒有錄入完成就進(jìn)行了刪除 導(dǎo)致會(huì)出現(xiàn)id重復(fù)的報(bào)錯(cuò)港华,建議還是把方法修改為批量加入的方法道川。當(dāng)然也是要加上事務(wù)的。
并且寫了一個(gè)定時(shí)任務(wù) 一分鐘執(zhí)行一次 保證實(shí)時(shí)數(shù)據(jù)的展示。
然后通過main方法執(zhí)行就可以了

/**
 * Created with IntelliJ IDEA.
 * User: employeeeee
 * Date: 2019/12/16
 * Time: 11:23
 * Description: No Description
 */
public class Main {
    public static void main(String[] args) {
        new Task();
    }
}

  1. 最后打jar包的時(shí)候 出現(xiàn)了
    java.lang.SecurityException: Invalid signature file digest for Manifest main attributes的報(bào)錯(cuò)
    最后通過
zip -d your.jar 'META-INF/.SF' 'META-INF/.RSA' 'META-INF/*SF'  

解決問題

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末愤惰,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子宦言,更是在濱河造成了極大的恐慌扇单,老刑警劉巖奠旺,帶你破解...
    沈念sama閱讀 211,042評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異响疚,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)忿晕,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,996評(píng)論 2 384
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來践盼,“玉大人鸦采,你說我怎么就攤上這事咕幻。” “怎么了肄程?”我有些...
    開封第一講書人閱讀 156,674評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)蓝厌。 經(jīng)常有香客問我玄叠,道長(zhǎng)褂始,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,340評(píng)論 1 283
  • 正文 為了忘掉前任崎苗,我火速辦了婚禮狐粱,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘胆数。我一直安慰自己肌蜻,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,404評(píng)論 5 384
  • 文/花漫 我一把揭開白布必尼。 她就那樣靜靜地躺著蒋搜,像睡著了一般篡撵。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上豆挽,一...
    開封第一講書人閱讀 49,749評(píng)論 1 289
  • 那天育谬,我揣著相機(jī)與錄音,去河邊找鬼帮哈。 笑死膛檀,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的娘侍。 我是一名探鬼主播咖刃,決...
    沈念sama閱讀 38,902評(píng)論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼憾筏!你這毒婦竟也來了嚎杨?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,662評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤氧腰,失蹤者是張志新(化名)和其女友劉穎枫浙,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體容贝,經(jīng)...
    沈念sama閱讀 44,110評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡自脯,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,451評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了斤富。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,577評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡锻狗,死狀恐怖满力,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情轻纪,我是刑警寧澤油额,帶...
    沈念sama閱讀 34,258評(píng)論 4 328
  • 正文 年R本政府宣布,位于F島的核電站刻帚,受9級(jí)特大地震影響潦嘶,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜崇众,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,848評(píng)論 3 312
  • 文/蒙蒙 一掂僵、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧顷歌,春花似錦锰蓬、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,726評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽麻顶。三九已至,卻和暖如春舱卡,著一層夾襖步出監(jiān)牢的瞬間辅肾,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,952評(píng)論 1 264
  • 我被黑心中介騙來泰國(guó)打工轮锥, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留矫钓,地道東北人交胚。 一個(gè)月前我還...
    沈念sama閱讀 46,271評(píng)論 2 360
  • 正文 我出身青樓蝴簇,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親熬词。 傳聞我的和親對(duì)象是個(gè)殘疾皇子旁钧,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,452評(píng)論 2 348