即使数据库中的数据可能是唯一的,任何特定查询的结果也可能不是——以我们的电影表为例,许多不同的电影可以在同一年上映。在这种情况下,SQL 提供了一种便捷的方法来使用DISTINCT
关键字丢弃具有重复列值的行。
SELECT DISTINCT column, another_column, … FROM mytable WHERE condition(s);
由于DISTINCT
关键字会盲目删除重复行,我们将在以后的课程中学习如何使用分组和GROUP BY
子句根据特定列丢弃重复项。
与上几课中我们整齐排列的表不同,真实数据库中的大多数数据都没有特定的列顺序添加。因此,随着表的大小增加到数千甚至数百万行,可能很难通读和理解查询的结果。
为了解决这个问题,SQL 提供了一种使用ORDER BY
子句按给定列按升序或降序对结果进行排序的方法。
SELECT column, another_column, … FROM mytable WHERE condition(s) ORDER BY column ASC/DESC;
当一个ORDER BY
指定的子句,每行是基于指定列的值排序的α-数值。在某些数据库中,您还可以指定排序规则以更好地对包含国际文本的数据进行排序。
与ORDER BY
子句一起使用的另一个子句是LIMIT
andOFFSET
子句,这是一种有用的优化,可以向数据库指示您关心的结果子集。
在LIMIT
将行的数量减少到回报,以及可选的OFFSET
将指定从哪里开始从计数的行数。
SELECT column, another_column, … FROM mytable WHERE condition(s) ORDER BY column ASC/DESC LIMIT num_limit OFFSET num_offset;