先看官網參考
代碼如下 復制代碼CONVERT(expr USING transcoding_name)
In MySQL, transcoding names are the same as the corresponding character set names.
Examples:
代碼如下 復制代碼 SELECT CONVERT(_latin1'Müller' USING utf8);SELECT CONVERT(latin1field USING utf8) FROM latin1table;CONVERT(... USING ...) is implemented according to the standard SQL specification.
You may also use CAST() to convert a string to a different character set. The syntax is:
CAST(character_string AS character_data_type CHARACTER SET charset_name)
Example:
代碼如下 復制代碼SELECT CAST(_latin1'test' AS CHAR CHARACTER SET utf8);
CONVERT()提供一個在不同字符集之間轉換數據的方法。語法是:
雙擊代碼全選 1 CONVERT(expr USING transcoding_name)
在 MySQL中,轉換代碼名與相應的字符集名相同。
例子:
代碼如下 復制代碼 SELECT CONVERT(_latin1'Müller' USING utf8);
根據標准SQL規范實施。
在傳統SQL模式中,如果你轉換一個“0”日期字符串到日期類型,CONVERT()函數返回NULL。在MySQL5.1中還產生一條警告。
示例表結構:
先來看一下,我的表結構
1 row in set (0.00 sec)因為有外鍵的存在,所以我不想改變字段類型,費勁啊。呵呵。雖然最後我還是選擇了更改字段類型,這是後話。因為我本篇日志想要說明的是varchar排序問題。所以不再說明我是如何更改字段類型的,大家有興趣可以搜索我以前的日志。(騙一下點擊)
現象描述:
下面,我從數據庫裡面以server_id排一下序,大家來看一下排序後的結果:
很明顯,我想要的結果應該是 10,8,7,6,5 這樣的。但是這個10排在了2的後面。按照字符串來排的。其實我是想把它當做數值來排。
手動轉換類型:
用下面的方法就可以了,使server_id+0之後再排序,問題解決了。
使用MySQL函數CAST/CONVERT:
mysql為我們提供了兩個類型轉換函數:CAST和CONVERT,現成的東西我們怎能放過?
CAST() 和CONVERT() 函數可用來獲取一個類型的值,並產生另一個類型的值。
這個類型 可以是以下值其中的 一個:
BINARY[(N)]
CHAR[(N)]
DATE
DATETIME
DECIMAL
SIGNED [INTEGER]
TIME
UNSIGNED [INTEGER]
所以我們也可以用CAST解決問題:
注:
就是CAST(xxx AS 類型), CONVERT(xxx,類型)。
可以轉換的類型是有限制的。這個類型可以是以下值其中的一個:
•二進制,同帶binary前綴的效果 : BINARY
•字符型,可帶參數 : CHAR()
•日期 : DATE
•時間: TIME
•日期時間型 : DATETIME
•浮點數 : DECIMAL
•整數 : SIGNED
•無符號整數 : UNSIGNED