ORACLE的order by中文排序

來源:互聯網
上載者:User

標籤:style   blog   http   使用   2014   line   log   c   

在使用order by排序的時候,出現如下情況:

 

印象中中文排序應該預設是按照拼音排序的,為何“鑫”會排在“中”的後面呢?猜想order by是不是根據對應字元的ASCII碼排的呢,因此列出了對應的ASCII,如下:

 

由此基本可以斷定,確實是通過ASCII的大小來排序的,這也解釋了為什麼數字會排在字母之前,字母為什麼會排在漢字之前的現象。但是為什麼會出現漢字預設是通過拼音排序的錯覺呢,於是查了一下漢字的編碼規則,有提到如下一句:

 

    “一級漢字,是最常用的漢字,按漢語拼音字母順序排列,共3755個;二級漢字,屬於次常用漢字,按偏旁部首的筆劃順序排列,共3008個”

可知,如果排序的漢字都是一級漢字的話,確實是按照拼音順序排列的,如果涉及到二級漢字,就不一定了。

 

但是,如果就是要讓漢字通過拼音順序排序呢,可以通過如下方式:

 

按照拼音順序

ORDER BY nlssort(NAME, ‘NLS_SORT=SCHINESE_PINYIN_M‘)

 

按照部首順序

ORDER BY nlssort(NAME, ‘NLS_SORT=SCHINESE_RADICAL_M‘)

 

按照筆畫順序

ORDER BY nlssort(NAME, ‘NLS_SORT=SCHINESE_STROKE_M‘)

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.