SQL 第四章 (AND, OR, NOT逻辑运算符)

目录

使用DATE_ADD函数能够对日期进行天数操作,可以对表名使用AS关键字,并在选择列时使用。

sql 复制代码
SELECT
	o.customer_id,
	o.order_id,
	o.order_date,
	DATE_ADD( o.order_date, INTERVAL 1 DAY ) AS new_date
FROM
	sql_store.orders AS o 
WHERE
	order_date >= '2018-1-1'

AND, OR, NOT运算符

本节将学习到ANDORNOT逻辑运算符,运算符的优先级,提升优先级的方法。

AND多条件WHERE子句查询

查询sql_store数据库下customers表,要求birth_date大于1980年1月1日且points大于1000的数据

sql 复制代码
SELECT *
FROM sql_store.customers
WHERE birth_date > '1980-1-1' AND points > 1000

AND和OR的WHERE子句查询

这里同时使用到了ANDOR,在逻辑运算符中,AND的优先级是大于OR的。可以看到翻译后的SQL,从左至右,由内到外,根据小括弧层次顺序来依次执行。

sql 复制代码
-- 查询sql_store数据库下customers表,要求birth_date大于1980年1月1日,并且points大于1000的,或者customer_id大于5的数据
SELECT *
FROM sql_store.customers
WHERE birth_date > '1980-1-1' AND points > 1000 OR customer_id > 5

-- 翻译后
SELECT *
FROM sql_store.customers
WHERE ((birth_date > '1980-1-1') AND (points > 1000)) OR (customer_id > 5)

AND、OR和NOT的WHERE子句查询

注意:这里不用小括弧包裹,那么根据优先级是NOT优先级是最高的,其次是AND。

sql 复制代码
-- 查询日期小于等于1980年1月1日,并且points大于1000,或者customer_id大于5的数据
SELECT *
FROM sql_store.customers
WHERE NOT birth_date > '1980-1-1' AND points > 1000 OR customer_id > 5

-- 翻译后, 默认你已经明白了比较运算符优先级是大于逻辑运算符的
SELECT *
FROM sql_store.customers
WHERE ((NOT birth_date > '1980-1-1') AND points > 1000) OR customer_id > 5

小结

通过以上的例子,相信你也明白了,通过小括弧的包裹,是可以提升SQL语句执行的优先级的。同时NOT的优先级是最高的,其次是AND,最后是OR
小知识:NOT、AND、OR分别对应着 !、&&、||,使用起来是同等效果。虽然这些非标准的操作符( !、&&、||)在某些 SQL 实现中可能可以正常工作,但在编写可移植的 SQL 代码时,最好还是使用标准的逻辑操作符,以确保在不同的数据库管理系统中都能正常运行。

练习

题目:查询sql_store数据库下的orders表,要求非comments字段不能为NULL,或者order_date大于2018年1月1日,并且status等于1的所有列数据。并使用小括弧给出翻译运行的顺序。

练习题答案

相关推荐
极小狐1 小时前
极狐GitLab 容器镜像仓库功能介绍
java·前端·数据库·npm·gitlab
极小狐1 小时前
如何构建容器镜像并将其推送到极狐GitLab容器镜像库?
开发语言·数据库·机器学习·gitlab·ruby
阿四啊2 小时前
【Redis实战篇】分布式锁-Redisson
数据库·redis·分布式
_星辰大海乀2 小时前
数据库约束
java·数据结构·数据库·sql·链表
多多*2 小时前
Java反射 八股版
java·开发语言·hive·python·sql·log4j·mybatis
一只fish2 小时前
MySQL 8.0 OCP 1Z0-908 题目解析(1)
数据库·mysql
AI大模型顾潇2 小时前
[特殊字符] 本地部署DeepSeek大模型:安全加固与企业级集成方案
数据库·人工智能·安全·大模型·llm·微调·llama
FAQEW2 小时前
MongDB和MySQL的区别
数据库·mysql·mongdb·区别
码农飞哥2 小时前
互联网大厂Java面试实战:Spring Boot到微服务的技术问答解析
java·数据库·spring boot·缓存·微服务·消息队列·面试技巧
niechel3 小时前
02-GBase 8s 事务型数据库 客户端工具dbaccess
数据库