SQL | 高级数据过滤
5-高级数据过滤
通过组合WHERE子句,建立功能更强的检索语句。
5.1-组合WHERE子句
前面写的都是单一条件下的WHERE子句,SQL语句允许给出多个WHERE子句来组合检索,这些WHERE子句通过AND子句或者OR子句进行连接。
操作符(operator) 用来联结或改变WHERE子句中的子句的关键字,也称为逻辑操作符(logical operator)。
5.1.1 AND操作符
要通过不止一个列进行过滤,可以通过AND操作符进行连接。
select prod_id,prod_price,prod_name
from products
where vend_id = 'DLL01' AND prod_price <= 4;
上述SQL语句用于检索由DLL01供应商提供的价格小于等于4元的所有产品的价格和名称。该条语句包含两个查询条件,一个是供应商id为DLL01,另一个条件为价格小于等于4,使用AND进行连接。

上述语句使用了一个AND连接符,因此只有两个过滤条件。可以增加多个过滤条件,每个条件之间都要使用AND连接符进行连接。
5.1.2 OR连接符
OR操作符与AND操作符正好相反,它指示DBMS检索匹配任一条件的行。事实上,许多DBMS在OR WHERE子句的第一个条件得到满足的情况下,就不再计算第二个条件了(在第一个条件满足时,不管第二个条件是否满足,相应的行都将被检索出来)。
select prod_id,prod_price,prod_name
from products
where vend_id = 'DLL01' OR vend_id = 'BRS01';

上述SQL语句通过OR连接符进行检索,只要满足任意一个条件,就会将数据纳入检索范围。
5.1.3 求值顺序
WHERE子句可以包含很多的AND和OR操作符。但是这么做可能会有一些小问题。
例如:想要列出价格为10元以上,且有DLL01或者BRS01制造的所有产品
select prod_id,prod_price,prod_name
from products
where vend_id = 'DLL01' or vend_id = 'BRS01' and prod_price >= 10;

可以看到,价格低于十元的产品也被输出了出来。
原因 在于求值顺序,SQL在处理OR操作符前,会优先处理AND操作符。当SQL看到上述语句时,会理解为:由供应商BRS01提供的10元以上的产品,以及由供应商DLL01提供的所有产品,而不管其价格如何。BRS01和价格大于等于10优先组合在一起。
解决办法是使用圆括号对操作符进行分组:
select prod_id,prod_price,prod_name
from products
where (vend_id = 'DLL01' OR vend_id = 'BRS01') AND prod_price >= 10;

圆括号具有比AND或OR操作符更高的优先级,所以DBMS首先过滤圆括号内的OR条件。
注意:任何时候使用具有AND和OR操作符的WHERE子句,都应该使用圆括号明确地分组操作符。不要过分依赖默认求值顺序,即使它确实如你希望的那样。使用圆括号没有什么坏处,它能消除歧义。
5.2-IN操作符
IN操作符用来指定条件范围,范围中的每个条件都可以进行匹配。
select prod_name,prod_price
from products
where vend_id IN ('DLL01','BRS01')
order by prod_name;

上述语句检索由供应商DLL01和供应商BRS01所提供的产品。
IN操作符完成的功能与OR操作符完成的功能类似。
select prod_name,prod_price
from products
where vend_id = 'DLL01' OR vend_id = 'BRS01'
order by prod_name;
两个语句输出的内容相同。
使用IN操作符的优点:
有很多合法选项时,IN操作符更为清晰明了。
在与其他AND和OR操作符组合使用IN时,求值顺序更容易理解。
IN操作符一般比一组OR操作符执行速度更快。
IN最大的优点是,可以包含其他select语句,能够更动态的建立where子句。
5.3-NOT操作符
WHERE子句中的NOT操作符有且只有一个作用,否定其后跟随的任何条件。
NOT从不单独使用,总是与其他操作符一起使用。
select prod_name
from products
where NOT vend_id = 'DLL01'
order by prod_name;
检索所有vend_id不是DLL01的行。
上面的语句也可以使用"<>"或者"!="来实现。
select prod_name
from products
where vend_id <> 'DLL01'
order by prod_name;select prod_name
from products
where vend_id != 'DLL01'
order by prod_name;
对于简单的where语句来说,使用NOT操作符确实没有多少优势,但是如果SQL语句比较复杂的话,NOT就非常有用。
例如,在与IN操作符联合使用时,NOT可以非常简单地找出与条件列表不匹配的行。
相关文章:
SQL | 高级数据过滤
5-高级数据过滤 通过组合WHERE子句,建立功能更强的检索语句。 5.1-组合WHERE子句 前面写的都是单一条件下的WHERE子句,SQL语句允许给出多个WHERE子句来组合检索,这些WHERE子句通过AND子句或者OR子句进行连接。 操作符(operato…...
ARM架构银河麒麟docker,源码编译安装GDAL
docker中安装依赖 sudo apt-get update sudo apt-get install build-essential autoconf automake libtool sudo apt-get install libproj-dev libgeos-dev libjson-c-dev libpng-dev libjpeg-dev sudo apt-get install python3-dev sudo apt-get install python3.11-dev去官网…...
(3)原神角色数据分析-3
绘图类 在名为“WRITEPHOT.py”的文件中,定义如下绘图方式,则在主页面(app.py)文件中,可通过如下方式调用: from WRITEPHOTO import WriteScatter,WriteFunnel,WriteBarData,WritePie,WriteLineBar 代码如下: "…...
skywalking日志收集
文章目录 一、介绍二、添加依赖三、修改日志配置1. 添加链路表示traceId2. 添加链路上下文3. 异步日志 四、收集链路日志 一、介绍 在上一篇文章skywalking全链路追踪中我们介绍了在微服务项目中使用skywalking进行服务调用链路的追踪。 本文在全链路追踪的基础上,…...
ASL国产CS5212规格书 DP转VGA 替代RTD2166低成本方案 兼容IT6516设计原理图
CS5212可替代兼容瑞昱RTD2166和联阳T6516,ASL集睿致远这款芯片是一种高性能的DP显示端口到VGA转换器芯片。它结合了DisplayPort输入接口和模拟RGB DAC输出接口,嵌入式单片机基于工业标准8051核心。 CS5212适用于多个细分市场和显示器应用程序࿱…...
关于Jquery的Validate插件--rules添加自定义方法(强密码验证方法)
简介:请看菜鸟教程,根据给出的方法,自定义识别密码是否为复杂密码的方法 链接: https://www.runoob.com/jquery/jquery-plugin-validate.html Query Validate 插件为表单提供了强大的验证功能,让客户端表单验证变得更简单&#…...
股票自动交易接口开发原理及源码分享
股票自动交易接口的开发原理涉及多个方面,主要包括以下几个步骤: 1. 数据接口获取:通过连接到证券交易所或第三方数据提供商的API,获取实时市场数据,包括股票报价、交易成交量、买卖盘口等信息。 2. 策略定义&#x…...
2023/8/11题解
时间限制: 1000MS 内存限制: 65536KB 解题思路 建树 模拟 ,复杂在于建树,此处从题目需求可知需要按层建树,所以需要队列模拟,查找比较容易就是普通的深搜 参考代码 #include<bits/stdc.h> using namespace std; vector<…...
构造函数
一、构造函数 构造函数用来在创建对象时初始化对象,为对象数据成员赋初始值。 类的数据成员是不能在类定义时初始化的,类定义并没有产生一个实体,而是给出了一个数据类型,不占用存储空间,无处容纳数据。 如果一个类…...
JS 原型与继承
本文内容学习于:后盾人 (houdunren.com) 一、原型对象 每个对象都有一个原型prototype对象,通过函数创建的对象也将拥有这个原型对象。 原型是一个指向对象的指针。 1.可以将原型理解为对象的父亲,对象从原型对象继承来属性 2.原型就是对象…...
解决 Oracle 数据库中表被锁问题的方案和方法
我们经常会遇到表被锁的情况,这可能会严重影响数据库的性能和可用性。我将与大家分享如何识别、分析和解决这些问题,以及如何使用特定的 SQL 查询来执行解锁操作。 了解表锁的原因 首先,让我们来了解一下导致表被锁的常见原因。长时间运行的…...
ORACLE行转列、列转行实现方式及案例
ORACLE行转列、列转行实现方式及案例 行转列案例方式1.PIVOT方式2.MAX和DECODE方式3.CASE WHEN和GROUP BY 列转行案例方式1.UNPIVOT方式2.UNION ALL 行转列 案例 假设我们有一个名为sales的表,其中包含了产品销售数据。表中有三列:product(…...
AI自动驾驶
AI自动驾驶 一、自动驾驶的原理二、自动驾驶的分类三、自动驾驶的挑战四、自动驾驶的前景五、关键技术六、自动驾驶的安全问题七、AI数据与自动驾驶八、自动驾驶的AI算法总结 自动驾驶技术是近年来备受关注的热门话题。它代表了人工智能和机器学习在汽车行业的重要应用。本文将…...
思维导图在职业规划中的应用:从职业选择到职业发展的思维导图
职业规划的重要性 在我们进行职业选择的时候,一个有效的职业规划,会对我们的未来有很大的帮助作用。一个好的职业规划可以帮助我们通过认识自己的兴趣、价值观、技能以及优势,找到适合自己的领域。并做出合理有效的职业选择。有了明确的职业目…...
antv l7每次刷新无法加载iconFont
如图,只渲染出了文本,未渲染出iconFont 但是如果我跳转到其他页面再跳转回来(未经过刷新时),可以展示出iconFont 解决: 查看官方源码后 找到了iconfont.tsx文件 可以看到多了一步font loaded, 放到项目中后再次测试&…...
28 玻尔兹曼机
文章目录 28 玻尔兹曼机28.1 模型定义28.2 梯度推导28.3 梯度上升28.4 基于VI[平均场理论]求解后验概率 28 玻尔兹曼机 28.1 模型定义 玻尔兹曼机是一张无向图,其中的隐节点和观测节点可以有任意连接如下图: 我们给其中的节点、连线做出一些定义&#…...
命令提示符之操作基础(Windows)
打开命令提示符 方法一 打开指定文件的文件夹,在路径栏里输入“cmd”,回车,就进入控制台了。默认路径就是指定文件夹的路径。 方法二 打开指定的文件夹,按住shift键,在空白处右击,在菜单栏中选择“在此处打…...
【C语言】初识C语言+进阶篇导读
✨个人主页: Anmia.🎉所属专栏: C Language 🎃操作环境: Visual Studio 2019 版本 本篇目的是面向编程新手,没接触过编程的人。以及C进阶的导读。 内容是C语言重要知识点的简单解释,不做详解。给…...
wxWidgets学习笔记:wxListCtrl使用详解
使用案例 wxListCtrl中放21个item,每一行放两个item,每个item显示图标和名字,点击某个图标,该图标呈现响应状态并响应对应的事件 以下是使用wxListCtrl实现放置21个item,每一行放两个item,每个item显示图…...
酷炫的python日志库-loguru
Loguru是一个python的日志库,比logging更简单,好用,功能丰富。 GitHub - Delgan/loguru: Python logging made (stupidly) simple 安装 pip install loguru 特征 开箱即用,补样板没有处理程序,没有清理程序ÿ…...
温湿度监控监测样本数据那温湿度阈值怎么设置?报警机制如何启动呢?
在医疗环境中,温湿度的监控对于保障样本安全、样本质量具有至关重要的作用,合理设置温湿度的上下限阈值,不仅能够及时发现环境异常,还能通过自动报警机制迅速响应,避免潜在风险的扩大。温湿度监控监测样本数据的上下…...
无监督视频实例分割的质量引导自训练框架解析
1. 无监督视频实例分割的核心挑战视频实例分割(Video Instance Segmentation, VIS)作为计算机视觉领域的前沿方向,同时面临着目标检测、语义分割和跨帧跟踪三重挑战。传统全监督方法虽然取得了显著进展,但其性能严重依赖于大量精确…...
Z-Image-GGUF快速部署指南:ComfyUI中一键加载阿里开源模型
Z-Image-GGUF快速部署指南:ComfyUI中一键加载阿里开源模型 1. 项目简介 Z-Image是阿里巴巴通义实验室开源的高质量文生图AI模型,类似于Stable Diffusion等主流图像生成模型。本指南将详细介绍如何在ComfyUI环境中快速部署GGUF量化版本的Z-Image模型。 …...
免费GPU显存稳定性终极测试指南:memtest_vulkan 5分钟快速上手
免费GPU显存稳定性终极测试指南:memtest_vulkan 5分钟快速上手 【免费下载链接】memtest_vulkan Vulkan compute tool for testing video memory stability 项目地址: https://gitcode.com/gh_mirrors/me/memtest_vulkan 你是否曾经遇到游戏崩溃、图形渲染错…...
别再乱复位了!嵌入式开发中NOR Flash擦除中断的实战避坑指南
嵌入式开发中NOR Flash擦除中断的实战避坑指南 在嵌入式系统开发中,NOR Flash因其高可靠性和快速随机读取特性,常被用于存储启动代码、操作系统内核等关键数据。然而,当系统遭遇意外复位或电源故障时,正在进行的Flash擦除操作可能…...
开源项目合规警示:从PyWxDump看技术边界与法律红线
开源项目合规警示:从PyWxDump看技术边界与法律红线 【免费下载链接】PyWxDump 删库 项目地址: https://gitcode.com/GitHub_Trending/py/PyWxDump 在开源技术蓬勃发展的今天,每一个开发者都梦想着创造能够解决实际问题的工具。然而,当…...
走进涠洲岛环岛路,解锁火山海岸原生态风光
涠洲岛静卧于广西北海市南部的海域之中,作为中国最大且最年轻的火山岛,其地表形态完整记录了第四纪以来火山喷发与海洋侵蚀的共同作用。环岛游所经之处,海蚀崖、熔岩台地、珊瑚碎屑滩、渔村石屋依次展开,构成了一座没有围墙的火山…...
Gitee:中国企业DevOps转型的本土化加速器
在数字化转型浪潮席卷各行各业的当下,DevOps作为提升软件交付效率的关键方法论,正成为企业技术架构升级的核心战场。Gitee作为国内领先的一站式DevOps平台,凭借其独特的本土化优势与全流程功能覆盖,正在帮助越来越多的中国企业突破…...
技术制衡 AI 乱象,重建信息真实
当生成式AI成为全民“信息入口”,一场隐蔽的信任危机正在爆发:AI“一本正经地胡说八道”、虚假产品被包装成“业界顶流”、恶意抹黑借算法扩散、GEO投毒污染全网信源……2026年央视315晚会曝光的AI“投毒”乱象,撕开了算法时代的信息黑幕——…...
3个实用技巧:使用Playwright Stealth绕过网站自动化检测
3个实用技巧:使用Playwright Stealth绕过网站自动化检测 【免费下载链接】playwright_stealth playwright stealth 项目地址: https://gitcode.com/gh_mirrors/pl/playwright_stealth 在当今的Web自动化测试和数据采集场景中,网站的反爬虫机制变得…...
