MYSQL資料庫字母數字混合欄位排序問題

來源:互聯網
上載者:User

標籤:欄位   uip   序列   結構   相同   rom   算術運算   數字   排序   

對MySQL資料表裡的一個字元型欄位排序,其內容格式為一位字母+順序數字。數字沒有前置字元為零,長度不固定。
這種含字母的數字序列,排序出來的結果和我們想要的結果是不一樣的,因為它不是純數字,只能按字元規則排。
結果是A1,A10,A11,A12。。。。A19,A2,A20,A21。。。。
而不是我們通常感覺中的A1,A2,A3,。。。。。A10,A11,這樣的結果。
想要得到正確的排序有兩個辦法。
一是改變欄位內容結構,在數字前加上零,讓所有的欄位值擁有相同的長度。
二是不改變欄位內容,在排序的SQL語句上想辦法。


order by mid(column,2,10) +1


mid()第一個參數是字串內容,可以是欄位名。第二個參數是起始字元的位置,我這裡需要從第二個字元開始。第三個參數是需要取得的長度,要選一個可以包含所有欄位內容長度的值,寧大勿小。
但這樣取出來的還只是“數字內容的字串”,對它排序仍然使用字元規則,不會得到我們想要的結果。
這時需要給這個結果再加上一個數值,讓MySQL對它進行一次算術運算,然後得到的就是一個整型值,這時再排序就是數字順序的結果了。
例如:
SELECT * FROM equipmentmes ORDER BY MID(eqid,2,10) +1

MYSQL資料庫字母數字混合欄位排序問題

相關文章

聯繫我們

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