sqoop import --hive-import --hive-overwrite --connect jdbc:oracle:thin:@192.168.92.136:1521:cyporcl --username ODS --password 'od154DS$!(' -m 1 --hive-database ODS --table Q_TRA_DISPUTESTATUS --fields-terminated-by '\001' --hive-drop-import-delims --null-string '\\N' --null-non-string '\\N' --map-column-java DISPUTERESULT=String
10年積累的成都做網(wǎng)站、成都網(wǎng)站建設(shè)、成都外貿(mào)網(wǎng)站建設(shè)經(jīng)驗(yàn),可以快速應(yīng)對客戶對網(wǎng)站的新想法和需求。提供各種問題對應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識你,你也不認(rèn)識我。但先制作網(wǎng)站后付款的網(wǎng)站建設(shè)流程,更有謝通門免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。DISPUTERESULT 這個字段是Oracleclob 類型的,里面有回車, 加載到hive 里面導(dǎo)致 記錄增多。
--map-column-java和--map-column-hive兩個參數(shù)都要顯示給出;還需要設(shè)置--hive-drop-import-delims這樣才能順利導(dǎo)出數(shù)據(jù)。
.導(dǎo)入的列有換行符如何解決
本以為萬事大吉,萬萬沒想到導(dǎo)入的列有nclob類型,里面存儲了一篇篇文章,勢必有著換行符。果不其然,hive查詢數(shù)據(jù)全部錯亂, 查詢資料發(fā)現(xiàn)--hive-delims-replacement(替換/n,/r等符號用你指定的字符)和--hive-drop-import-delims參數(shù)??商砑由先グl(fā)現(xiàn)并沒有什么卵用,沒有起作用。百度goole很久,終于發(fā)現(xiàn)一篇帖子,http://stackoverflow.com/questions/28076200/hive-drop-import-delims-not-removing-newline-while-using-hcatalog-in-sqoop
意思是要用--map-column-java參數(shù)來顯示指定列為String類型。我的解決方案為 --map-column-java 我的CLOB列=String 果然,問題解決,換行符全部被去掉。不過聽說改變存儲格式 或許也可以避免這個問題,希望有著經(jīng)驗(yàn)的大神來回答一下。總結(jié)下來就這么多,希望能幫助大家
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。