在 MySQL 中,ORDER BY columnname*1 的目的是什么?
MySQL 会隐式地将该列转换为一个数字。以下是语法 −
select * from yourTableName order by yourColumnName*1;
让我们首先创建一个 −
mysql> create table DemoTable1441 -> ( -> Id varchar(30) -> ); Query OK, 0 rows affected (0.53 sec)
使用 insert 向表中插入一些记录 −
mysql> insert into DemoTable1441 values('301'); Query OK, 1 row affected (0.21 sec) mysql> insert into DemoTable1441 values('23'); Query OK, 1 row affected (0.23 sec) mysql> insert into DemoTable1441 values('345'); Query OK, 1 row affected (0.42 sec) mysql> insert into DemoTable1441 values('10'); Query OK, 1 row affected (0.23 sec) mysql> insert into DemoTable1441 values('38'); Query OK, 1 row affected (0.11 sec)
使用 select 从表中显示所有记录 −
mysql> select * from DemoTable1441;
这将产生以下输出 −
+------+ | Id | +------+ | 301 | | 23 | | 345 | | 10 | | 38 | +------+ 5 rows in set (0.00 sec)
以下是使用 order by columnname*1 的查询 −
mysql> select * from DemoTable1441 -> order by id*1;
这将产生以下输出 −
+------+ | Id | +------+ | 10 | | 23 | | 38 | | 301 | | 345 | +------+ 5 rows in set (0.00 sec)
广告