<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    飛翔的起點

    從這里出發

    導航

    <2008年6月>
    25262728293031
    1234567
    891011121314
    15161718192021
    22232425262728
    293012345

    統計

    常用鏈接

    留言簿(5)

    隨筆分類

    隨筆檔案

    文章分類

    文章檔案

    搜索

    最新評論

    閱讀排行榜

    評論排行榜

    java中使用oracle的exp/imp導出、導入數據

              今天在學習的過程中遇到了一篇關于java中使用oracle導入導出的文章,感覺還不錯,為了學習和以后工作的需要,我整理如下:
               String[] cmds 
    = new String[3];
            cmds[
    0= "cmd";
            cmds[
    1= "/C";
            cmds[
    2]=commandBuf.toString();
            Process process
    =Runtime.getRuntime().exec(cmds);
            
    boolean shouldClose=false;
            
    try {
                InputStreamReader isr 
    = new InputStreamReader(process.getErrorStream());
                BufferedReader br 
    = new BufferedReader(isr);
                String line 
    = null;
                
    while ((line = br.readLine()) != null){
                    
    if(line.indexOf("錯誤")!=-1){
                        shouldClose
    =true;
                        
    break;
                    }

                }

            }
     
            
    catch (IOException ioe) {
                shouldClose
    =true;
            }

            
    if(shouldClose)
                process.destroy();
            
    int exitVal = process.waitFor();

            下面還有一種形式:
    exp和imp的輸出是要從ErrorStream中獲取,這是我以前寫的
    Process proc = null;
    try
    {
    proc = Runtime.getRuntime().exec(cmd.toString());
    InputStream istr = proc.getErrorStream();
    BufferedReader br = new BufferedReader(new InputStreamReader(istr));
    String str;
    while ((str=br.readLine()) != null)
    {
    errorInfo.append(str + "\n");
    }
    proc.waitFor();
    }
    catch (Exception e)
    {
    ...
    }
    if (proc.exitValue() == 0)
    {
    proc.destroy();
    return true;
    }
    else
    {
    if(logger.isDebugEnabled())
    logger.debug(errorInfo);
    proc.destroy();
    return false;

    兩者可以比較的看看
    注意:在執行oracle的exp時,出現了一個很怪的現象,就是exp在console輸出的信息沒有被放入InputStream,反而是放到了ErrorStream中(即使正確的情況也是),這就導致了按照正常的情況去寫這段代碼的話反而會出問題。---這是在jdk1.4環境下實現的。



    還有中建議是在jdk1.5環境下:可以如下實現
    1,把對InputStream的處理放到一個單獨Thread里面。
    2,用ProcessBuilder的redirectErrorStream來合并OutputStream和ErrorStream。注意子進程的InputStream對應父進程的OutStream。如果不合并這兩個流的話則必須并行排空它們,順序的排空會導致思索。

    posted on 2008-06-13 11:57 forgood 閱讀(839) 評論(0)  編輯  收藏 所屬分類: java

    主站蜘蛛池模板: 2022年亚洲午夜一区二区福利| 久久精品国产精品亚洲下载| 久久久久亚洲av无码专区导航| 黄 色一级 成 人网站免费| 亚洲高清偷拍一区二区三区| 亚洲a∨国产av综合av下载| 免费观看美女裸体网站| 亚洲人成电影网站免费| 精品久久久久久久免费人妻| 亚洲一区二区三区成人网站| 最好免费观看韩国+日本| 亚洲国产精品99久久久久久| 国产嫩草影院精品免费网址| 国产免费观看视频| 黄页网站在线观看免费| 2048亚洲精品国产| 久久福利青草精品资源站免费| 亚洲成人午夜在线| 一色屋成人免费精品网站| 蜜芽亚洲av无码一区二区三区| 亚洲国产香蕉人人爽成AV片久久| 中国好声音第二季免费播放| 18gay台湾男同亚洲男同| 在线免费观看a级片| xvideos永久免费入口| 久久亚洲伊人中字综合精品| 无码av免费毛片一区二区| 亚洲精品理论电影在线观看| 亚洲免费一区二区| 91麻豆国产免费观看| 亚洲AV无码专区国产乱码电影| 人妻仑乱A级毛片免费看| 亚洲国产精品乱码一区二区| 国产免费毛不卡片| 免费激情网站国产高清第一页| 亚洲AV无一区二区三区久久| 成人激情免费视频| 热99RE久久精品这里都是精品免费 | 国产一区二区视频免费| 中文字幕的电影免费网站| 亚洲专区中文字幕|