程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> MYSQLVARCHAR排序CAST,CONVERT函數類型轉換

MYSQLVARCHAR排序CAST,CONVERT函數類型轉換

編輯:MySQL綜合教程

MYSQLVARCHAR排序CAST,CONVERT函數類型轉換


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

示例表結構:

先來看一下,我的表結構
	
show create table cardserver \G
*************************** 1. row ***************************
       Table: cardserver
Create 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=gbk
1 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函數。


  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved