MySql varchar排序 CAST ,CONVERT及用法

來源:互聯網
上載者:User

先看官網參考

 代碼如下 複製代碼

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);
INSERT INTO utf8table (utf8column)

    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);
INSERT INTO utf8table (utf8column) SELECT CONVERT(latin1field USING utf8) FROM latin1table; CONVERT(... USING ...)

根據標準SQL規範實施。

  在傳統SQL模式中,如果你轉換一個“0”日期文字到日期類型,CONVERT()函數返回NULL。在MySQL5.1中還產生一條警告。

 

樣本表結構:
先來看一下,我的表結構

 代碼如下 複製代碼
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         |
+-----------+

注:

就是CAST(xxx AS 類型), CONVERT(xxx,類型)。

可以轉換的類型是有限制的。這個類型可以是以下值其中的一個:

•二進位,同帶binary首碼的效果 : BINARY   
•字元型,可帶參數 : CHAR()    
•日期 : DATE    
•時間: TIME    
•日期時間型 : DATETIME    
•浮點數 : DECIMAL     
•整數 : SIGNED    
•不帶正負號的整數 : UNSIGNED

相關文章

聯繫我們

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