Oracle中如何用SQL檢測欄位是否包括中文字元

來源:互聯網
上載者:User

Oracle中如何用SQL檢測欄位是否包括中文字元

 

      今天有一個同事的資料移轉程式有個問題,沒有考慮中文編碼字元,由於遷移的表有幾千萬資料,但是有中文的記錄集很少,問我能否找出有中文內容的記錄數。首先我想到的是採用檢測每個位元組ASCII的方式,這樣的話需要寫一個自訂函數,然後SQL中調用得到結果。但是感覺這個方法估計很耗時,畢竟每個字元都要比較,所以沒有去實現。突然想到Oracle有一個編碼轉換的函數叫Convert,如果一個字串編碼轉換前後不一樣就表示字串裡面含有非ASCII字元,這樣就得到結果。最後寫出來測試了一下,確實可行,5500萬記錄10秒鐘就掃描結束。以下是測試案例:

 

SQL> select *
  2    from (select 'abcd' c1 from dual
  3          union all
  4          select 'ab測試cd' c1 from dual)
  5   where c1 <> CONVERT(c1, 'US7ASCII', 'ZHS16GBK');
 
C1
--------
ab測試cd

 

 

CONVERT函數說明:

CONVERT(inputstring,dest_charset,source_charset)

 

inputstring:要轉換的字串

dest_charset:目標字元集

source_charset:原字元集

 

 

這隻是一個小技巧,也許有一天你也有這樣的需求,或許能派上用場。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.