《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

相关文章

Springboot中分析SQL性能的两种方式详解

《Springboot中分析SQL性能的两种方式详解》文章介绍了SQL性能分析的两种方式:MyBatis-Plus性能分析插件和p6spy框架,MyBatis-Plus插件配置简单,适用于开发和测试环... 目录SQL性能分析的两种方式:功能介绍实现方式:实现步骤:SQL性能分析的两种方式:功能介绍记录

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

oracle DBMS_SQL.PARSE的使用方法和示例

《oracleDBMS_SQL.PARSE的使用方法和示例》DBMS_SQL是Oracle数据库中的一个强大包,用于动态构建和执行SQL语句,DBMS_SQL.PARSE过程解析SQL语句或PL/S... 目录语法示例注意事项DBMS_SQL 是 oracle 数据库中的一个强大包,它允许动态地构建和执行

SQL 中多表查询的常见连接方式详解

《SQL中多表查询的常见连接方式详解》本文介绍SQL中多表查询的常见连接方式,包括内连接(INNERJOIN)、左连接(LEFTJOIN)、右连接(RIGHTJOIN)、全外连接(FULLOUTER... 目录一、连接类型图表(ASCII 形式)二、前置代码(创建示例表)三、连接方式代码示例1. 内连接(I

在MySQL执行UPDATE语句时遇到的错误1175的解决方案

《在MySQL执行UPDATE语句时遇到的错误1175的解决方案》MySQL安全更新模式(SafeUpdateMode)限制了UPDATE和DELETE操作,要求使用WHERE子句时必须基于主键或索引... mysql 中遇到的 Error Code: 1175 是由于启用了 安全更新模式(Safe Upd

Spring排序机制之接口与注解的使用方法

《Spring排序机制之接口与注解的使用方法》本文介绍了Spring中多种排序机制,包括Ordered接口、PriorityOrdered接口、@Order注解和@Priority注解,提供了详细示例... 目录一、Spring 排序的需求场景二、Spring 中的排序机制1、Ordered 接口2、Pri

Redis的数据过期策略和数据淘汰策略

《Redis的数据过期策略和数据淘汰策略》本文主要介绍了Redis的数据过期策略和数据淘汰策略,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录一、数据过期策略1、惰性删除2、定期删除二、数据淘汰策略1、数据淘汰策略概念2、8种数据淘汰策略

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

MySql死锁怎么排查的方法实现

《MySql死锁怎么排查的方法实现》本文主要介绍了MySql死锁怎么排查的方法实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录前言一、死锁排查方法1. 查看死锁日志方法 1:启用死锁日志输出方法 2:检查 mysql 错误

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意