MYSQL VARCHAR排序 CAST ,CONVERT函數 類型轉換,varcharconvert

來源:互聯網
上載者:User

MYSQL VARCHAR排序 CAST ,CONVERT函數 類型轉換,varcharconvert

自己建表的時候,把一個欄位類型建立為varchar(2) ,其實應該建為integer(2)的,但是今天在後台發現排序有問題,varchar排序有問題,所以該怎麼解決呢?

樣本表結構:先來看一下,我的表結構show create table cardserver \G*************************** 1. row ***************************       Table: cardserverCreate Table: CREATE TABLE `cardserver` (  `id` int(11) NOT NULL default '0',  `ver` int(11) default NULL,  `createtime` datetime default NULL,  `updatetime` datetime default NULL,  `game_id` int(2) NOT NULL default '0',  `server_id` varchar(2) NOT NULL default '',  `server_name` varchar(40) NOT NULL default '',  PRIMARY KEY  (`id`),  UNIQUE KEY `game_id_server_id` (`game_id`,`server_id`),  UNIQUE KEY `game_id_server_name` (`game_id`,`server_name`)) ENGINE=InnoDB DEFAULT CHARSET=gbk1 row in set (0.00 sec)因為有外鍵的存在,所以我不想改變欄位類型,費勁啊。呵呵。雖然最後我還是選擇了更改欄位類型,這是後話。因為我本篇日誌想要說明的是varchar排序問題。所以不再說明我是如何更改欄位類型的,大家有興趣可以搜尋我以前的日誌。(騙一下點擊)現象描述:下面,我從資料庫裡面以server_id排一下序,大家來看一下排序後的結果:select server_id from cardserver where game_id = 1 order by server_id desc limit 10;+-----------+| server_id |+-----------+| 8         | | 7         | | 6         | | 5         | | 4         | | 3         | | 2         | | 10        | | 1         | +-----------+很明顯,我想要的結果應該是 10,8,7,6,5 這樣的。但是這個10排在了2的後面。按照字串來排的。其實我是想把它當做數值來排。手動轉換類型:用下面的方法就可以了,使server_id+0之後再排序,問題解決了。select server_id from cardserver where game_id = 1 order by server_id+0 desc limit 10;+-----------+| server_id |+-----------+| 10        | | 8         | | 7         | | 6         | | 5         | | 4         | | 3         | | 2         | | 1         | +-----------+使用MySQL函數CAST/CONVERT:mysql為我們提供了兩個類型轉換函式:CAST和CONVERT,現成的東西我們怎能放過?    CAST() 和CONVERT() 函數可用來擷取一個類型的值,併產生另一個類型的值。    這個類型 可以是以下值其中的 一個:    BINARY[(N)]    CHAR[(N)]    DATE    DATETIME    DECIMAL    SIGNED [INTEGER]    TIME    UNSIGNED [INTEGER] 所以我們也可以用CAST解決問題:select server_id from cardserver where game_id = 1 order by CAST(server_id as SIGNED) desc limit 10;+-----------+| server_id |+-----------+| 10        | | 8         | | 7         | | 6         | | 5         | | 4         | | 3         | | 2         | | 1         | +-----------+也可以使用CONVERT來搞定此問題:select server_id from cardserver where game_id = 1 order by CONVERT(server_id,SIGNED) desc limit 10;+-----------+| server_id |+-----------+| 10        | | 8         | | 7         | | 6         | | 5         | | 4         | | 3         | | 2         | | 1         | +-----------+總結:條條大道通羅馬,條條小路通我家。不管是啥方法,解決問題就是好方法。當然,既然MySQL為我們提供了現成的函數。我們為何不讓代碼顯得更漂亮些呢?呵呵。所以MySql varchar排序我推薦使用CAST或CONVERT函數。


相關文章

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.