《MySQL必知必会》过滤数据,数据过滤

1、过滤数据

1.1 使用 where 子句

在SEL ECT语句中,数据根据WHERE子句中指定的搜索条件进行过滤。

WHERE子句在表名(FROM子句) 之后给出,如下所示:

select *
from orders
where Date(order_date) = '2005-09-01';

需要注意的是,不仅SQL有数据过滤,在实际开发中,应用层也会有数据过滤。但是通常这样是不能令人满意的。

因此要对数据库进行优化,以便快速有效地对数据进行过滤,让应用层去解决数据过滤,这将会影响到应用的性能。并且使所创建的应用完全不具备可伸缩性。此外,如果在客户机上过滤数据,服务器不得不通过网络发送多余的数据,这将导致网络带宽的浪费。

总之,提高数据库的性能,也是开发中非常重要的一部分。

WHERE子句的位置在同时使用ORDER BY和WHERE子句时

应该让ORDER BY位于WHERE之后,否则将会产生错误。

1.2 where子句操作符

操作符 说明
= 等于
<> 不等于(推荐使用)
!= 不等于
< 小于
<= 小于等于
> 大于
>= 大于等于
between 在指定两值区间内
select order_date
from orders
where Date(order_date) <> '2005-09-01';

SELECT prod_name,prod_price
FROM products
WHERE prod_price BETWEEN 5 AND 10;

其他语句,可以自行尝试编写执行。

这里需要特别注意的是,空值查询

select cust_name , cust_email
from customers
where cust_email is null;

这里返回的数据,只包括查询字段为空值的数据。

那么,is not null 查出来的数据将会是怎么样的呢?

select cust_name , cust_email
from customers
where cust_email is not null;

所有的非空值都会匹配。

同时,注意null 值是不会作为不匹配数据被查询出来。

现有数据如上。

select cust_name , cust_zip
from customers
where cust_zip <> '88888';

null 值的数据将被不匹配查询过滤,因为数据库也不知道它是否匹配,对于数据库来说,它是未知的,是有特殊含义的。

2、 数据过滤

2.1 组合where子句

可以用 and 和 or 关键字,组合 where 子句。

select  order_date
from orders
where year(order_date) = 2005 and month(order_date) = 9;

select  order_date
from orders
where year(order_date) = 2005 or month(order_date) = 9;

这里有一个and 和 or 执行优先级的问题。

select  order_num,order_date
from orders
where year(order_date) = 2005 and month(order_date) = 9 or cust_id = 10001;

由上面的查询结果,可知,DBMS 先处理 and 操作符,再处理 or 。and 的优先级 > or 。

还可以使用圆括号来制定优先处理。

select  order_num,order_date
from orders
where year(order_date) = 2005 and ( month(order_date) = 9 or cust_id = 10001 );

不要过分依赖计算次序。复杂的 and 部分用圆括号也是可以的,虽然并未改变计算顺序,但是能消除歧义,便于阅读,这间接方便了后期维护,这是值得推崇的。

2.2 IN 操作符

IN 操作符用来指定条件范围,在指定范围内对每个条件进行匹配。(注意与between 的用法区分开来, between 表示匹配区间范围内的值)

SELECT prod_name,prod_price
FROM products
WHERE prod_price in (10 , 13, 50);

IN 是具有和 or 相同的功能,但是 IN 有着他自身的优点。

  • 在使用长的合法选项清单时,IN操作符的语法更清楚且更直观
  • 在使用IN时, 计算的次序更容易管理(因为使用的操作符更少)。
  • IN操作符- -般比0R操作符清单执行更快
  • IN的最大优点是可以包含其他SELECT语句,使得能够更动态地建立WHERE子句。第14章将对此进行详细介绍。

2.3 NOT 操作符

select cust_name , cust_email
from customers
where cust_email is not null;

所有的非空值都会匹配。

MySQL中的NOT MySQL支持使用NOT对IN、BETWEEN和EXISTS子句取反,这与多数其他DBMS允许使用NOT对各种条件取反有很大的差别。

《MySQL必知必会》过滤数据,数据过滤(where ,in ,null ,not)的更多相关文章

  1. MySql必知必会实战练习(三)数据过滤

    在之前的博客MySql必知必会实战练习(一)表创建和数据添加中完成了各表的创建和数据添加,MySql必知必会实战练习(二)数据检索中介绍了所有的数据检索操作,下面对数据过滤操作进行总结. 1. whe ...

  2. 【SQL必知必会笔记(3)】SELECT语句的WHERE子句数据过滤操作

    上个笔记主要介绍了利用SELECT语句检索单个/多个/所有列,并利用DISTINCT关键字检索具有唯一性的值.利用LIMIT/OFFSET子句限制结果:以及利用ORDER BY子句排序检索出的数据,主 ...

  3. 《MySQL必知必会》检索数据,排序检索数据(select ,* ,distinct ,limit , . , order by ,desc)

    <MySQL必知必会>检索数据,排序检索数据 1.检索数据 1.1 select 语句 为了使用SELECT检索表数据,必须至少给出两条信息一想选择什 么,以及从什么地方选择. 1.2 检 ...

  4. 【SQL必知必会笔记(2)】检索数据、排序检索数据

    上个笔记中介绍了一些关于数据库.SQL的基础知识,并且创建我们后续练习所需的数据库.表以及表之间的关系,从本文开始进入我们的正题:SQL语句的练习. 文章目录 1.检索数据(SELECT语句) 1.1 ...

  5. 【SQL必知必会笔记(1)】数据库基础、SQL、MySQL8.0.16下数据库、表的创建及数据插入

    文章目录 1.数据库基础 1.1 数据库(database) 1.2 表(table) 1.3 列和数据类型 1.4 行 1.5 主键 2.什么是SQL 3.创建后续练习所需数据库.表(MySQL8. ...

  6. 《MySQL 必知必会》读书总结

    这是 <MySQL 必知必会> 的读书总结.也是自己整理的常用操作的参考手册. 使用 MySQL 连接到 MySQL shell>mysql -u root -p Enter pas ...

  7. 《MySQL必知必会》[01] 基本查询

    <MySQL必知必会>(点击查看详情) 1.写在前面的话 这本书是一本MySQL的经典入门书籍,小小的一本,也受到众多网友推荐.之前自己学习的时候是啃的清华大学出版社的计算机系列教材< ...

  8. mysql必知必会系列(一)

    mysql必知必会系列是本人在读<mysql必知必会>中的笔记,方便自己以后查看. MySQL. Oracle以及Microsoft SQL Server等数据库是基于客户机-服务器的数据 ...

  9. mysql必知必会

    春节放假没事,找了本电子书mysql必知必会敲了下.用的工具是有道笔记的markdown文档类型. 下面是根据大纲已经敲完的章节,可复制到有道笔记的查看,更美观. # 第一章 了解SQL## 什么是S ...

随机推荐

  1. kafka笔记——入门介绍

    中文文档 目录 kafka的优势 首先几个概念 kafka的四大核心API kafka的基本术语 主题和日志(Topic和Log) 每个分区都是一个顺序的,不可变的队列,并且可以持续的添加,分区中的每 ...

  2. 记一次svg反爬学习

    网址:http://www.porters.vip/confusion/food.html 打开开发者工具后 页面源码并不是真实的数字,随便点一个d标签查看其样式 我们需要找到两个文件,food.cs ...

  3. 《闲扯Redis八》Redis字典的哈希表执行Rehash过程分析

    一.前言 随着操作的不断执行, 哈希表保存的键值对会逐渐地增多或者减少, 为了让哈希表的负载因子(load factor)维持在一个合理的范围之内, 当哈希表保存的键值对数量太多或者太少时, 程序需要 ...

  4. LQB2013A02排它平方数

    这个题方向其实还算好找,就是枚举嘛 (这是一个填空题,所以六个for嵌套也无所谓,因为毕竟emmmm,不看时间) 这里是判断的代码: 需要把数字转化成字符串 void i2s(int x,string ...

  5. 保姆级教程,如何发现 GitHub 上的优质项目?

    先看再点赞,给自己一点思考的时间,微信搜索[沉默王二]关注这个靠才华苟且的程序员.本文 GitHub github.com/itwanger 已收录,里面还有一线大厂整理的面试题,以及我的系列文章. ...

  6. C/C++编程笔记:C语言NULL值和数字 0 值区别及NULL详解

    在学习C语言的时候,我们常常会碰到C语言NULL值和数字 0 ,很多小伙伴搞不清楚他们之间的一个区别,今天我们就了解一下他们之间的区别,一起来看看吧! 先看下面一段代码输出什么: 输出<null ...

  7. bzoj 2839 集合计数 容斥\广义容斥

    LINK:集合计数 容斥简单题 却引出我对广义容斥的深思. 一直以来我都不理解广义容斥是为什么 在什么情况下使用. 给一张图: 这张图想要表达的意思就是这道题目的意思 而求的东西也和题目一致. 特点: ...

  8. java多线程之锁 -- 偏向锁、轻量级锁、自旋锁、重量级锁

    转载至:https://blog.csdn.net/zqz_zqz/article/details/70233767 之前做过一个测试,详情见这篇文章<多线程 +1操作的几种实现方式,及效率对比 ...

  9. MySQL-安装配置篇

    一.MySQL二进制安装包安装 1.环境初始化 1)创建目录mkdir /app/database --安装路径 mkdir /data/3306 --存放数据路径 mkdir /binlog/330 ...

  10. 面试:Java基础知识(一)

    1.面向对象的特征有哪些方面  1.抽象: 抽象就是忽略一个主题中与当前目标无关的那些方面,以便更充分地注意与当前目标有关的方面.抽象并不打算了解全部问题,而只是选择其中的一部分,暂时不用部分细节.抽 ...