sql varchar排序CAST/CONVERT实现语句

是今天在后台发现排序有问题。于是,没办法,改之。下面简单说一下MySQL的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         |
+-----------+

总结:方法有很多要看自己动脑子了,所谓的条条大道通罗马也是这个意思了。

时间: 2024-10-10 15:17:40

sql varchar排序CAST/CONVERT实现语句的相关文章

MySql varchar排序 CAST ,CONVERT及用法

先看官网参考  代码如下 复制代码 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 C

SQL的排序,分组,统计常用语句

  SQL的排序,分组,统计常用语句: 1.使用排序使数据有序 通常,你的所有数据真正需要的仅仅是按某种顺序排列.SQL的ORDER BY语句可以以字母或数字顺序组织数据.因此,相似的值按组排序在一起.然而,这个分组时排序的结果,并不是真的分组.ORDER BY显示每条记录而分组可能代表很多记录. 2.进行分组除去重复值 排序和分组之间的最大区别是:排序的数据显示所有记录(在限定标准范围之内),而分组数据不是显示所有记录.GROUP BY语句对于同样的值只显示一条记录.例如,下面的语句中的GRO

MySql中varchar,char类型排序CAST CONVERT

简单说一下MySQL的varchar排序问题,引以为戒. 示例表结构: 先来看一下,我的表结构  代码如下 复制代码 show create table cardserver G *************************** 1. row *************************** Table: cardserver Create Table: CREATE TABLE `cardserver` ( `id` int(11) NOT NULL default '0', `v

SQL 导入导出Excel数据的语句_MsSql

--从Excel文件中,导入数据到SQL数据库中,很简单,直接用下面的语句: /*===================================================================*/ --如果接受数据导入的表已经存在 insert into 表 select * from OPENROWSET('MICROSOFT.JET.OLEDB.4.0' ,'Excel 5.0;HDR=YES;DATABASE=c:\test.xls',sheet1$) --如果导入

SQL 导入导出Excel数据的语句

--从Excel文件中,导入数据到SQL数据库中,很简单,直接用下面的语句: /*===================================================================*/ --如果接受数据导入的表已经存在 insert into 表 select * from OPENROWSET('MICROSOFT.JET.OLEDB.4.0' ,'Excel 5.0;HDR=YES;DATABASE=c:\test.xls',sheet1$) --如果导入

修改SQL数据库排序规则修改表栏位排序规则

  修改SQL数据库排序规则修改表栏位排序规则 修改SQL数据库排序规则: 1.修改为单用户模式 2.然后关闭所有的查询窗口,修改Options的Collocation属性,如:Chinese_PRC_90_CI_AS 3.再修改为多用户模式 修改表栏位排序规则: 使用存储过程处理,可以指定对应的表, 存储过程处理步骤: 1-刪除外鍵 (含对应的sql语句) 2-刪除主鍵 (含对应的sql语句) 2.5-删除索引 (含对应的sql语句) 3-修改排序规则 (含对应的sql语句) 4-生成主鍵 (

criteria-请问Hibernate中CriteriaQuery可以使用原生sql作为排序条件么

问题描述 请问Hibernate中CriteriaQuery可以使用原生sql作为排序条件么 请问Hibernate中Criteria Query可以使用原生sql作为排序条件么? 正常情况下是 addOrder(Order.desc("column")); 希望order by nvl(column,'xxxx') desc 类似Hibernate 的条件查询就支持原生sql. 请问排序支持么?我搜索了一下,没有找到类似的api. 当然我使用hql就可以了,但是我前提已经使用了Cri

sql 两个字段相减语句

sql 两个字段相减语句 本文章搜索了大量来自网络的关于sql 两个字段相减语句与函数代码,举例说明了两个字段相减做法. select a.字段1,字段2=a.字段2-isnull((select 字段2 from 表2 where a.字段1=字段1),0) from 表1 a 方法二 create  table 表1( 字段1 varchar(50),   字段2 int) insert into 表1 select       '111001' ,   10  union all sele

提高SQL Server伸缩性的四个语句

本文讲解如何使用LEFT JOIN.CROSS JOIN以及IDENTITY值的检索,这些技术来提高基于SQL Server的应用程序的性能或改善其可伸缩性. 你将遇到的现象:应用程序中的SQL 查询不能按照您想要的方式进行响应.它要么不返回数据,要么耗费的时间长得出奇.如果它降低了企业应用程序的速度,用户必须等待很长时间.用户希望应用程序响应迅速,他们的报告能够在瞬间之内返回分析数据. 为了解决这些问题,重要的是找到问题的根源.那么,从哪里开始呢?根本原因通常在于数据库设计和访问它的查询.我将