最近在开发中遇到了字段进行排序问题,字段类型是varchar类型 转换为INTEGER 进行排序:

举个例子:例如我们要进行排序的字段是 name_id 为varchar 要进行排序

select * from book where order by name_id desc, 此种排序肯定不是想要的下面两种方式为你想想的

select * from book  order by (name_id+0) desc

select * from book  order by (name_id as unsigned) desc

select  * from book  order by CONVERT(name_id,SIGNED) desc

为我们提供了两个类型转换函数:CAST和CONVERT,现成的东西我们怎能放过?

CAST() 和CONVERT() 函数可用来获取一个类型的值,并产生另一个类型的值。

这个类型 可以是以下值其中的 一个:
BINARY[(N)]
CHAR[(N)]
DATE
DATETIME
DECIMAL
SIGNED [INTEGER]
TIME
UNSIGNED [INTEGER]

UNSIGNED 解释

整型的每一种都有无符号(
unsigned)和有符号(
signed)两种类型,在默认情况下声明的 都是有符号的类型(
char有点特别),如果需声明无符号类型的话就需要在类型前加上
unsigned。无符号版本和有符号版本的区别就是无符号类型能保存2倍于有符号类型的数据,比如16位系统中一个int能存储的数据的范围为–32768 ~ 32767(16位2进制的最高位作为符号位‘1’为负‘0’为正),而
unsigned能存储的数据范围则是0~65535(这个最高位不用做符号位,所以是2的16次方,一共65536)。由于在 中,整数是以 形式存放的。根据最高位的不同,如果是1,有符号数的话就是负数;如果是无符号数,则都解释为正数。同时在相同位数的情况下,所能表达的整数范围变大。另外,
unsigned若省略后一个关键字,大多数编译器都会认为是
unsigned int
在sql语句中的意义
sql语句中,创建一个数据表时
ceate table user{
user_id int unsigned
}
当中的unsigned表示,数据项user_id恒为正整数。