MySQL Order By语法介绍

 更新时间:2012年07月29日 23:30:08   作者:  
今天在使用ORDER BY的过程中出现了一点问题,发现之前对ORDER BY理解是错误的
今天在使用ORDER BY的过程中出现了一点问题,发现之前对ORDER BY理解是错误的。

之前在w3s网站上看到ORDER BY的用法,以为是对选出来的数据按关键字升序或者降序排列,结果今天尝试select数据集数据的时候,发现使用ORDER BY 和ORDER BY DESC得出的查询结果完全不一样,按照自己之前的理解它们应该是结果相同,而内部顺序不一样而已。

问了一下同事,查了一下文档,才恍然大悟。如果我们在执行select语句的时候使用ORDER BY (DESC),那么它首先会对所有记录按照关键字有一个排序,然后依次读取所需的记录,而不是先选出记录再进行降序排列。 一个概念性的错误,所以记下来警示自己。

MySQL Order By keyword是用来给记录中的数据进行分类的。

MySQL Order By Keyword根据关键词分类

ORDER BY keyword是用来给记录中的数据进行分类的。

MySQL Order By语法
复制代码 代码如下:

SELECT column_name(s)
FROM table_name
ORDER BY column_name

注意:SQL语句是“字母大小写不敏感”的语句(它不区分字母的大小写),即:“ORDER BY”和“order by”是一样的。

MySQL Order By案例

下面的例子:从“Person”表中选取所有记录,并将“Age”列进行分类:
复制代码 代码如下:

<?php
$con = mysql_connect("localhost","peter","abc123");
if (!$con)
{
die('Could not connect: ' . mysql_error());
}
mysql_select_db("my_db", $con);
$result = mysql_query("SELECT * FROM person ORDER BY age");
while($row = mysql_fetch_array($result))
{
echo $row['FirstName']
echo " " . $row['LastName'];
echo " " . $row['Age'];
echo "<br />";
}
mysql_close($con);
?>
[html]
上面的代码将输出下面的结果:

Glenn Quagmire 33

Peter Griffin 35

按照升序或者降序进行分类排列

如果你使用了“ORDER BY”关键词,所有记录将按照默认的升序进行排列(即:从1到9,从a到z)

使用“DESC”关键词可以制定所有的数据按照降序排列(即:从9到1,从z到a):
[code]
SELECT column_name(s)
FROM table_name
ORDER BY column_name DESC

MySQL Order By根据两列进行分类

很多时候,我们需要同时根据两列内容(或者更多列)来对数据进行分类。当指定的列数多于一列时,仅在第一列的值完全相同时才参考第二列:
复制代码 代码如下:

SELECT column_name(s)
FROM table_name
ORDER BY column_name1, column_name2

相关文章

  • win10 mysql 5.6.35 winx64免安装版配置教程

    win10 mysql 5.6.35 winx64免安装版配置教程

    这篇文章主要为大家详细介绍了win10 mysql 5.6.35 winx64免安装版配置教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-05-05
  • MySQL索引不会被用到的情况汇总

    MySQL索引不会被用到的情况汇总

    这篇文章主要给大家介绍了关于MySQL索引不会被用到的一些情况,文中通过示例代码介绍的非常详细,对大家学习或者使用MySQL具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-08-08
  • 高级MySQL数据库面试问题 附答案

    高级MySQL数据库面试问题 附答案

    绝对精彩的文章,11个高级MySQL数据库面试问题,每个问题都给出了具体答案,感兴趣的小伙伴们可以参考一下
    2016-07-07
  • MySQL手动注册binlog文件造成主从异常的原因

    MySQL手动注册binlog文件造成主从异常的原因

    这篇文章主要介绍了MySQL手动注册binlog文件造成主从异常的原因,帮助大家更好的理解和使用MySQL数据库,感兴趣的朋友可以了解下
    2020-10-10
  • MySql登陆密码忘记及忘记密码的解决方案

    MySql登陆密码忘记及忘记密码的解决方案

    这篇文章主要介绍了MySql登陆密码忘记的解决方案以及mysql忘记密码的快速解决方法,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-03-03
  • MYSQL代码 定期备份Mysql数据库

    MYSQL代码 定期备份Mysql数据库

    Mysql自动备份脚本供大家参考,实现了定期备份Mysql数据库,并且可以选在在每周的一天做指定目录下文件的全面备份,备份文件自动上传到你指定的FTP上,保证了备份的可靠性。
    2009-04-04
  • 关于MySQL表中没有主键时如何找到重复的数据

    关于MySQL表中没有主键时如何找到重复的数据

    这篇文章主要来和探讨一下关于MySQL表中没有主键时,该如何找到重复的数据,文中的示例代码讲解详细,具有一定的参考价值,需要的可以了解一下
    2023-06-06
  • 当mysqlbinlog版本与mysql不一致时可能导致出哪些问题

    当mysqlbinlog版本与mysql不一致时可能导致出哪些问题

    这篇文章主要介绍了当mysql服务器为mysql5.6时,mysqlbinlog版本不对可能导致出哪些问题,下面通过模拟2种场景分析此类问题,需要的朋友可以参考下
    2015-07-07
  • 保证MySQL与Redis数据一致性的6种实现方案

    保证MySQL与Redis数据一致性的6种实现方案

    这篇文章将聚焦在一个非常重要且复杂的问题上:MySQL与Redis数据的一致性,当我们在应用中同时使用MySQL和Redis时,如何保证两者的数据一致性呢?下面就来分享几种实用的解决方案,需要的朋友可以参考下
    2024-03-03
  • mysql免安装版配置教程

    mysql免安装版配置教程

    这篇文章主要为大家详细介绍了mysql免安装版配置教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-01-01

最新评论