《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

相关文章

MyBatis 动态 SQL 优化之标签的实战与技巧(常见用法)

《MyBatis动态SQL优化之标签的实战与技巧(常见用法)》本文通过详细的示例和实际应用场景,介绍了如何有效利用这些标签来优化MyBatis配置,提升开发效率,确保SQL的高效执行和安全性,感... 目录动态SQL详解一、动态SQL的核心概念1.1 什么是动态SQL?1.2 动态SQL的优点1.3 动态S

Mysql表的简单操作(基本技能)

《Mysql表的简单操作(基本技能)》在数据库中,表的操作主要包括表的创建、查看、修改、删除等,了解如何操作这些表是数据库管理和开发的基本技能,本文给大家介绍Mysql表的简单操作,感兴趣的朋友一起看... 目录3.1 创建表 3.2 查看表结构3.3 修改表3.4 实践案例:修改表在数据库中,表的操作主要

SpringIntegration消息路由之Router的条件路由与过滤功能

《SpringIntegration消息路由之Router的条件路由与过滤功能》本文详细介绍了Router的基础概念、条件路由实现、基于消息头的路由、动态路由与路由表、消息过滤与选择性路由以及错误处理... 目录引言一、Router基础概念二、条件路由实现三、基于消息头的路由四、动态路由与路由表五、消息过滤

Java利用JSONPath操作JSON数据的技术指南

《Java利用JSONPath操作JSON数据的技术指南》JSONPath是一种强大的工具,用于查询和操作JSON数据,类似于SQL的语法,它为处理复杂的JSON数据结构提供了简单且高效... 目录1、简述2、什么是 jsONPath?3、Java 示例3.1 基本查询3.2 过滤查询3.3 递归搜索3.4

mysql出现ERROR 2003 (HY000): Can‘t connect to MySQL server on ‘localhost‘ (10061)的解决方法

《mysql出现ERROR2003(HY000):Can‘tconnecttoMySQLserveron‘localhost‘(10061)的解决方法》本文主要介绍了mysql出现... 目录前言:第一步:第二步:第三步:总结:前言:当你想通过命令窗口想打开mysql时候发现提http://www.cpp

MySQL大表数据的分区与分库分表的实现

《MySQL大表数据的分区与分库分表的实现》数据库的分区和分库分表是两种常用的技术方案,本文主要介绍了MySQL大表数据的分区与分库分表的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有... 目录1. mysql大表数据的分区1.1 什么是分区?1.2 分区的类型1.3 分区的优点1.4 分

MySQL错误代码2058和2059的解决办法

《MySQL错误代码2058和2059的解决办法》:本文主要介绍MySQL错误代码2058和2059的解决办法,2058和2059的错误码核心都是你用的客户端工具和mysql版本的密码插件不匹配,... 目录1. 前置理解2.报错现象3.解决办法(敲重点!!!)1. php前置理解2058和2059的错误

Mysql删除几亿条数据表中的部分数据的方法实现

《Mysql删除几亿条数据表中的部分数据的方法实现》在MySQL中删除一个大表中的数据时,需要特别注意操作的性能和对系统的影响,本文主要介绍了Mysql删除几亿条数据表中的部分数据的方法实现,具有一定... 目录1、需求2、方案1. 使用 DELETE 语句分批删除2. 使用 INPLACE ALTER T

MySQL INSERT语句实现当记录不存在时插入的几种方法

《MySQLINSERT语句实现当记录不存在时插入的几种方法》MySQL的INSERT语句是用于向数据库表中插入新记录的关键命令,下面:本文主要介绍MySQLINSERT语句实现当记录不存在时... 目录使用 INSERT IGNORE使用 ON DUPLICATE KEY UPDATE使用 REPLACE

MySQL Workbench 安装教程(保姆级)

《MySQLWorkbench安装教程(保姆级)》MySQLWorkbench是一款强大的数据库设计和管理工具,本文主要介绍了MySQLWorkbench安装教程,文中通过图文介绍的非常详细,对大... 目录前言:详细步骤:一、检查安装的数据库版本二、在官网下载对应的mysql Workbench版本,要是