MySQL Order By语法介绍

所属分类: 数据库 / Mysql 阅读数: 2588
收藏 0 赞 0 分享
今天在使用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 创建索引(Create Index)的方法和语法结构及例子

MySQL 创建索引(Create Index)的方法和语法结构及例子
收藏 0 赞 0 分享

MYSQL 优化常用方法

如何优化你的MYSQL呢?请看下面:(不错的优化方案)
收藏 0 赞 0 分享

linux mysql 找回密码

linux下mysql忘记密码的解决方法。
收藏 0 赞 0 分享

mysql 动态执行存储过程语句

MSSQL中动态执行sql语句可以使用EXEC()函数。MSSQL中也有类似的函数EXECUTE(),不过不同的是MYSQL中动态执行存储过程语句与MSSQL还是有区别的。
收藏 0 赞 0 分享

MySQL 查找价格最高的图书经销商的几种SQL语句

不同的图书,在不同的经销商的价格不同,我们这里要找到每种图书最高的经销商是谁? 找最低的类似了。
收藏 0 赞 0 分享

MySQL 客户端不输入用户名和密码直接连接数据库的2个方法

MySQL 客户端不输入用户名和密码直接连接数据库的2个方法,大家可以测试下。
收藏 0 赞 0 分享

mysql 查询表中平均分最低的班级

查询出dd(user_id,class_no,score)这个表中平均分最低的班级?
收藏 0 赞 0 分享

mysql 左连接、右连接和内连接

以MySql为例。在MySQL数据库中建立两张数据表,并分别插入一些数据。
收藏 0 赞 0 分享

Mysql LONGBLOB 类型存储二进制数据 (修改+调试+整理)

代码来自网络,我学习整理了一下,测试通过,下面的参数需要设置为你自己的
收藏 0 赞 0 分享

Mysql LONGTEXT 类型存储大文件(二进制也可以) (修改+调试+整理)

MySql2.cpp : Defines the entry point for the console application.
收藏 0 赞 0 分享
查看更多