《SQL必知必会——第3、4、5课:排序检索数据及过滤数据》

2024-08-28 13:58

本文主要是介绍《SQL必知必会——第3、4、5课:排序检索数据及过滤数据》,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

       第3课  排序检索数据

       这一课主要讲order by用法,看似很简单,实际有些细节还可以说说。

       order by子句的位置:在指定一条order by子句时,应该保证它是select语句中的最后一条子句,否则将会出错。

       order by按多个列排序:指定列名,列名之间用逗号分开即可;除此之外,还可以按照相对位置排序,比如order by 2, 3,即先按表的第2列,在按照表的第3列排序,由于是序号而非列名,可能会搞错,这种用法平时用的也比较少 。

       指定排序方向:也就是升序和降序。升序是asc(ascending),降序是desc(descending),升序是默认的,可以不用指定。如果需要降序输出,则需要指定desc,比如order by price desc,这里面desc关键字作用范围仅限于其前面的列名,也就是说order by price desc,name,将按照价格price降序排序,然后按照名称name升序排序。

       这一课差不多这些知识点,order by还是比较好理解的。

       第4、5课  过滤数据

       过滤数据自然就是讲where用法。where子句有很多操作符,等于:=、不等于:<> 或 !=、 大于:>、大于等于:>=、小于:<、小于等于:<=、between、is null等。上述操作符有些dbms不支持,因为每家dbms风格也是有一点点不同的,如:access支持<>而不支持!=。上面操作符,between属于范围检查操作符,使用时需要和and关键字搭配使用,同时还需要制定范围的低端值和高端值,如:select name, price from products where price between 5 and 10;

       空值检查

       编程过程中,所有工程师都无法逃避的一个问题,那就是空值检查,c和c++尤其多,java虽然不用指针,但是照样需要做大量的空值检查,为此很多编程语言专门设计了空值检查类或者关键字。和在程序中不同,在数据库中,空值指的是在一个列不包含值时,称其包含空值NULL。空值也就是无值,而0、空字符串、空格等等,这都是值,不能与NULL划等号,所以,在设计数据库时,NULL值与0和空字符串,是完全不同的。检查空值需使用is null操作符,如:select name, price from products where price is null;

       组合where子句

       过滤数据,可以理解成就是if操作,if操作有与&&和或||,那么自然where子句也有and和or,也就是组合更多的条件来过滤数据。and操作符,也就是&&操作,表示检索满足所有给定条件的数据。or操作符,也就是||操作,用来表示检索匹配任一给定条件的行。那么and和or一起用会怎么样呢?if中 && 和 || 一起用会怎么样,它就会怎么样。所以,为了避免出现歧义,建议使用圆括号()明确地将各个条件括起来,就像写if判断一样,避免出现由于求值顺序问题导致的数据查询错误。

       说完了and和or,在说说in操作符。in操作符用来指定条件范围,范围中的每个条件都可以进行匹配。如:select name,price from products where name in ('mac pro', 'think pad'),其实就是or操作符所执行的功能,一样一样的。但是,很明显一个in可以搞定,省去了很多or,sql语句更简洁了,还有更重要的,那就是in操作符比一组or操作符执行更快。

       最后说一下not操作符,这个操作符可以理解成就是平时编程时用的!操作符,连使用位置都一样,都是放在前面。也就是要过滤的列前面。比如:select name,price from products where not name = 'mac pro'; 这样一看,似乎not操作符并没什么卵用,因为上面完全可以这样写:select name,price from products where name != 'mac pro'; 但是当not与其他操作符联合使用时,威力才能发挥出来,比如和in一起,not in,就可以找出与条件列表不匹配的数据,如:select name,price from products where name not in ('mac pro', 'think pad')。越复杂的sql,这些操作符越能发挥出威力,当然还是尽量避免写太复杂的sql。

 

 

这篇关于《SQL必知必会——第3、4、5课:排序检索数据及过滤数据》的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1114956

相关文章

如何使用 Python 读取 Excel 数据

《如何使用Python读取Excel数据》:本文主要介绍使用Python读取Excel数据的详细教程,通过pandas和openpyxl,你可以轻松读取Excel文件,并进行各种数据处理操... 目录使用 python 读取 Excel 数据的详细教程1. 安装必要的依赖2. 读取 Excel 文件3. 读

Windows 上如果忘记了 MySQL 密码 重置密码的两种方法

《Windows上如果忘记了MySQL密码重置密码的两种方法》:本文主要介绍Windows上如果忘记了MySQL密码重置密码的两种方法,本文通过两种方法结合实例代码给大家介绍的非常详细,感... 目录方法 1:以跳过权限验证模式启动 mysql 并重置密码方法 2:使用 my.ini 文件的临时配置在 Wi

MySQL重复数据处理的七种高效方法

《MySQL重复数据处理的七种高效方法》你是不是也曾遇到过这样的烦恼:明明系统测试时一切正常,上线后却频频出现重复数据,大批量导数据时,总有那么几条不听话的记录导致整个事务莫名回滚,今天,我就跟大家分... 目录1. 重复数据插入问题分析1.1 问题本质1.2 常见场景图2. 基础解决方案:使用异常捕获3.

Spring 请求之传递 JSON 数据的操作方法

《Spring请求之传递JSON数据的操作方法》JSON就是一种数据格式,有自己的格式和语法,使用文本表示一个对象或数组的信息,因此JSON本质是字符串,主要负责在不同的语言中数据传递和交换,这... 目录jsON 概念JSON 语法JSON 的语法JSON 的两种结构JSON 字符串和 Java 对象互转

SQL中redo log 刷⼊磁盘的常见方法

《SQL中redolog刷⼊磁盘的常见方法》本文主要介绍了SQL中redolog刷⼊磁盘的常见方法,将redolog刷入磁盘的方法确保了数据的持久性和一致性,下面就来具体介绍一下,感兴趣的可以了解... 目录Redo Log 刷入磁盘的方法Redo Log 刷入磁盘的过程代码示例(伪代码)在数据库系统中,r

mysql中的group by高级用法

《mysql中的groupby高级用法》MySQL中的GROUPBY是数据聚合分析的核心功能,主要用于将结果集按指定列分组,并结合聚合函数进行统计计算,下面给大家介绍mysql中的groupby用法... 目录一、基本语法与核心功能二、基础用法示例1. 单列分组统计2. 多列组合分组3. 与WHERE结合使

C++如何通过Qt反射机制实现数据类序列化

《C++如何通过Qt反射机制实现数据类序列化》在C++工程中经常需要使用数据类,并对数据类进行存储、打印、调试等操作,所以本文就来聊聊C++如何通过Qt反射机制实现数据类序列化吧... 目录设计预期设计思路代码实现使用方法在 C++ 工程中经常需要使用数据类,并对数据类进行存储、打印、调试等操作。由于数据类

Mysql用户授权(GRANT)语法及示例解读

《Mysql用户授权(GRANT)语法及示例解读》:本文主要介绍Mysql用户授权(GRANT)语法及示例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql用户授权(GRANT)语法授予用户权限语法GRANT语句中的<权限类型>的使用WITH GRANT

Mysql如何解决死锁问题

《Mysql如何解决死锁问题》:本文主要介绍Mysql如何解决死锁问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录【一】mysql中锁分类和加锁情况【1】按锁的粒度分类全局锁表级锁行级锁【2】按锁的模式分类【二】加锁方式的影响因素【三】Mysql的死锁情况【1

SpringBoot使用GZIP压缩反回数据问题

《SpringBoot使用GZIP压缩反回数据问题》:本文主要介绍SpringBoot使用GZIP压缩反回数据问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录SpringBoot使用GZIP压缩反回数据1、初识gzip2、gzip是什么,可以干什么?3、Spr