麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發設計 > 正文

集算器協助java處理結構化文本之對齊連接

2019-11-14 14:52:56
字體:
來源:轉載
供稿:網友

  數據庫有關聯語句,可以方便地進行對齊連接運算,但有時數據是存儲在文本文件中的,用java直接計算需要寫大量循環語句才能實現,代碼繁瑣且運行低效。使用集算器來輔助Java編程,可以方便高效地解決此類問題。下面我們通過例子來看一下具體作法。

  文本文件emp.txt存儲著員工信息,EId等于1的員工不在該文件中。文本文件sOrder.txt存儲著訂單信息,其SellerId字段和emp中的EId字段相對應,SellerId等于2的訂單不在該表中。部分源數據如下:

  emp.txt

sOrder.txt

現在需要將emp的Name、Dept、Gender這三個字段對齊到sOrder中,計算結果輸出到新文件中。期望的計算結果如下:

集算器代碼:

A1格和A2格分別從文本文件中讀取數據,并存入兩個變量emp和sOrder。這里使用了函數import,其默認的列分割符是tab,函數選項@t表示將第一行讀為字段名。由于例子中只需要emp.txt中的部分字段,因此A1需要以字段名做參數。計算完成后,emp和sOrder的值如下圖:

A3:=join@1(sOrder:s,SellerId;emp:e,EId)。函數join執行連接運算,并將兩個表改名為s和e。其中函數選項@1表示左連接,即例子中的要求:將emp對齊到sOrder中。計算后結果如下:

點擊藍色鏈接可以看到具體的記錄,如下:

右連接只是交換對齊的位置,同樣可以用集算器來實現。比如將sOrder按照emp對齊,只需要在代碼中交換兩者的順序,即=join@1(emp:e,EId;sOrder:s,SellerId),計算結果如下:

全連接也很容易實現,只需要使用函數選項@f,代碼是:join@f(sOrder:s,SellerId;emp:e,EId),計算結果如下:

連接運算共有四種,除了上面提到的左連接、右連接、全連接,還有內連接。函數join默認執行內連接,代碼是=join(sOrder:s,SellerId;emp:e,EId),計算結果如下:

回到例子中,A4:=A3.new(s.OrderID, s.Client, s.SellerId, s.Amount, s.OrderDate, e.Name, e.Dept, e.Gender)。這句代碼從連接的表中取得需要的字段,組成新的結構化二維表格,計算結果如下:

對齊的工作已經完成,下面將數據輸出到新的文件,代碼為:=file(“E: //result.txt”).export@t(A4)。

函數export默認使用tab作為列分割符,函數選項@t表示將字段名輸出在第一行。打開result.txt,可以看到內容如下:

上述腳本已經完成了所有的對其輸出工作,接下來只需在JAVA代碼中調用即可。

    //建立esPRoc jdbc連接
     Class.forName(“com.esproc.jdbc.InternalDriver”);
     con= DriverManager.getConnection(“jdbc:esproc:local://”);
     //調用esProc,其中test是腳本文件名
     st =(com.esproc.jdbc.InternalCStatement)con.prepareCall(“call test()”);
     //執行esProc存儲過程
     st.execute();

只要執行上述JAVA代碼,emp就會對齊到sOrder中,并將計算結果輸出到result.txt文件。

下面將例子稍作改動:按動態的時間段查詢sOrder中的數據,并執行同樣的對齊操作,最后直接將結果返回JAVA。為了實現這個例子,集算器需要定義兩個參數,分別是begin和end,代表起止時間。集算器代碼如下:

紅色部分為改動的代碼。

  A2:通過函數select對sOrder進一步過濾,過濾條件為JAVA傳來的起止時間,即@begin和@end。

  A5:將A4中的計算結果輸出到JDBC接口。

  JAVA代碼也需要進行相應的改動,以便傳入參數,并獲取計算結果。代碼如下:

    Class.forName(“com.esproc.jdbc.InternalDriver”);
     con= DriverManager.getConnection(“jdbc:esproc:local://”);
     st =(com.esproc.jdbc.InternalCStatement)con.prepareCall(“call test(?,?)”);
    st.setObject(1,startTime);
     st.setObject(2,endTime);
    st.execute();
    ResultSet set = st.getResultSet();


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 55夜色66夜色国产精品视频 | 亚洲一区久久 | 亚洲一区二区国产 | 亚洲最大中文字幕 | 国产69精品久久久久孕妇黑 | 欧美日韩国产一区二区三区在线观看 | 久久精品亚洲精品国产欧美kt∨ | 狠狠干网站 | 日韩高清影视 | 国产精品一区在线看 | 精品国产99久久久久久宅男i | 久草在线新视觉 | 黄色的视频免费观看 | 日本在线播放一区二区三区 | 中文字幕免费播放 | 欧美日韩一区二区综合 | 久久精片 | 久久最新视频 | 亚洲91精品 | 亚洲天堂在线电影 | 精品国产一区二区三区四区阿崩 | 亚洲热线99精品视频 | 青青草国产在线视频 | 99re热视频这里只精品 | 牛牛碰在线 | 黄色网址免费进入 | 少妇一级淫片高潮流水电影 | 亚洲一区久久 | 国产精品久久久久久影院8一贰佰 | 国产无遮挡一区二区三区毛片日本 | 综合毛片 | 爽爽淫人网 | 欧美日韩在线视频一区 | jizzjizz中国少妇中文 | 亚洲午夜影院在线观看 | 国产污污视频 | 久久国产精品久久久久 | 久久国产精品久久久久久 | 成人区一区二区 | 激情久久一区二区 | 国产精品欧美久久久久一区二区 |