MySQL Order By语法介绍
程序员文章站
2024-02-14 13:00:22
今天在使用order by的过程中出现了一点问题,发现之前对order by理解是错误的。 之前在w3s网站上看到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
之前在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
上一篇: Android4.4 Uri获取图片及document理解
下一篇: yii2源码(2)--路由