ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

SQL:过滤和排序查询结果

2021-07-16 13:36:02  阅读:174  来源: 互联网

标签:column SQL mytable 查询 过滤 子句 排序 ORDER


即使数据库中的数据可能是唯一的,任何特定查询的结果也可能不是——以我们的电影表为例,许多不同的电影可以在同一年上映。在这种情况下,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子句一起使用的另一个子句是LIMITandOFFSET子句,这是一种有用的优化,可以向数据库指示您关心的结果子集。
LIMIT将行的数量减少到回报,以及可选的OFFSET将指定从哪里开始从计数的行数。

选择行数有限的查询(OFFSET第一行是1)

SELECT column, another_column, … FROM mytable WHERE condition(s) ORDER BY column ASC/DESC LIMIT num_limit OFFSET num_offset;

标签:column,SQL,mytable,查询,过滤,子句,排序,ORDER
来源: https://www.cnblogs.com/lhTest/p/15019620.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有