• 技术文章 >数据库 >MySQL

    mysql如何排序

    yangyang2020-04-07 16:56:55原创2058

    使用SELECT抽取数据时,数据的显示是无序的,想要得到有序的数据,那么我们就需要使用ORDER BY子句进行排序。

    ORDED BY 子句语法:

    SELECT <列1>,<列2>,<列3>,......

    FROM <表名>

    ORDER BY <排序基准1>,<排序基准2>,.....

    ORDED BY 子句(商品的销售单价升序排列)

    其中desc表示降序,asc表示升序排列。

    示例:

    这里先创建一张普通的表

    CREATE TABLE `test1` (
      `id` bigint(20) NOT NULL AUTO_INCREMENT,
      `name` varchar(50) NOT NULL,
      `date_time` datetime NOT NULL,
      `status` int(5) NOT NULL,
      PRIMARY KEY (`id`)
    ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8

    再添加一些测试数据

    INSERT INTO `test1` VALUES
    (NULL, '测试1', '2018-03-05 11:09:00', 1),(NULL, '测试2', '2018-03-06 11:09:00', 1),(NULL, 'abc', '2018-03-07 11:09:00', 1), 
    (NULL, 'def', '2018-04-08 11:09:00', 2),(NULL, '李某某', '2018-04-17 11:09:00', 1),(NULL, '饭某某', '2018-04-20 13:09:00', 2),
    (NULL, '赵', '2018-04-20 01:09:00', 4),(NULL, '倩', '2018-04-28 11:09:00', 2),(NULL, 'andy', '2018-04-30 11:09:00', 1),
    (NULL, 'tony', '2018-05-08 11:09:00', 4),(NULL, 'tom', '2018-05-07 11:09:00', 3),(NULL, 'bill', '2018-05-18 11:09:00', 3),
    (NULL, 'james', '2018-06-07 11:09:00', 4),(NULL, 'anthony', '2018-06-18 11:09:00', 2),(NULL, '盖茨', '2018-04-21 11:09:00', 1),
    (NULL, '部长', '2018-04-24 11:09:00', 4),(NULL, '李总', '2018-04-20 11:09:00', 5),(NULL, '张总', '2018-04-29 11:09:00', 2),
    (NULL, '王总', '2018-04-19 11:09:00', 3),(NULL, '唐总', '2018-05-01 11:09:00', 2);

    有了数据,开始针对这些数据,做一些排序:

    1、单列排序

    SELECT * FROM test1 ORDER BY date_time

    默认升序,降序后面接"DESC"即可。

    2、多列排序

    SELECT * FROM test1 ORDER BY `status`, date_time DESC

    首先按`status`字段排序,若`status`相等,则按data_time排序。

    3、自定义排序

    SELECT * FROM test1 ORDER BY FIELD(`status`, 3, 2, 4, 1, 5), date_time DESC

    使用"FIELD()"函数,可指定顺序。

    4、其他条件排序

    先按大于等于当前时间升序,再按小于当前时间降序,支持分页。

    SELECT * FROM test1 ORDER BY date_time < NOW(), IF(date_time < NOW(), 0, date_time), date_time DESC

    推荐:MySQL教程

    专题推荐:mysql
    上一篇:如何查看mysql数据库的表 下一篇:怎么查看mysql版本

    相关文章推荐

    • mysql的配置文件在哪• mysql判断是否为空的方法• 如何查看mysql数据库的表

    全部评论我要评论

    © 2021 Python学习网 苏ICP备2021003149号-1

  • 取消发布评论
  • 

    Python学习网