MySQL Order By语法介绍

时间:2024-01-19 03:29:48 

今天在使用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
标签:MySQL,Order
0
投稿

猜你喜欢

  • python实现人像动漫化的示例代码

    2021-08-16 06:36:17
  • vue货币过滤器的实现方法

    2024-05-09 10:40:58
  • Python基于正则表达式实现检查文件内容的方法【文件检索】

    2021-06-11 07:58:45
  • 浅谈ES6 模板字符串的具体使用方法

    2024-04-18 10:02:01
  • ASP申请单动态添加实现方法及代码

    2008-11-04 11:09:00
  • Python实现的求解最小公倍数算法示例

    2022-12-11 04:50:03
  • 详解vue模拟加载更多功能(数据追加)

    2024-05-22 10:41:44
  • Python元素集合的列表切片

    2023-08-08 23:08:57
  • python图片验证码识别最新模块muggle_ocr的示例代码

    2021-03-28 11:49:26
  • 利用SQL语句对不同数据库进行高效果分页

    2008-11-28 14:44:00
  • 分发服务器 系统抛出18483错误,未能连接服务器,因为'distributor_admin'未定义远程登陆

    2024-01-24 00:39:48
  • Node.js中Bootstrap-table的两种分页的实现方法

    2024-05-11 10:58:21
  • Mootools常用方法扩展(二)

    2009-01-11 18:22:00
  • PHP实现的DES加密解密类定义与用法示例

    2023-07-17 08:55:54
  • 详解vue-router2.0动态路由获取参数

    2024-04-09 10:49:42
  • Python 中的装饰器实现函数的缓存(场景分析)

    2022-07-30 01:37:08
  • Python中Matplotlib的点、线形状、颜色以及绘制散点图

    2023-06-11 00:32:26
  • Vue中的 DOM与Diff详情

    2023-07-02 16:32:37
  • XMLHTTP错误The server name or address could not be resolved 的解决过程

    2009-12-26 18:33:00
  • 基于Django的ModelForm组件(详解)

    2022-03-07 18:21:04
  • asp之家 网络编程 m.aspxhome.com