SQL基础教程读书笔记-1
查询基础
2.2 算数运算符和比较运算符
2.2.1算数运算符
+ - * /
需要注意NULL
- 5 + NULL
- 10 - NULL
- 1 * NULL
- 4 / NULL
- NULL / 9
- NULL / 0
以上运算结果全都是NULL,实际上所有包含NULL的运算,结果肯定是NULL。
2.2.2比较运算符
1.
运算符 | 含义 |
---|---|
= | 和~相等 |
<> | 和~不相等 |
>= | 大于等于~ |
> | 大于~ |
< | 小于~ |
<= | 小于等于~ |
2.对字符串使用不等号时的注意事项
字符串类型的数据原则上按照字典进行排序
例如:
11 > 2
但是 '11'<'2'
3.不能对NULL使用比较运算符
希望选取NULL记录时,需要在条件表达式中使用IS NULL运算符;希望选取不是NULL的记录时,需要在条件表达式中使用IS NOT NULL 运算符。
2.2.3逻辑运算符
1.SQL中的逻辑运算包含对真、假和不确定进行运算的三值逻辑。
运算符 | 含义 |
---|---|
NOT | 否定某一条件 |
AND | 并且 |
OR | 或 |
2.AND优先级高于OR,优先执行OR可以使用括号。
3.三值逻辑中的AND和OR真值表
AND
P | Q | P AND Q |
---|---|---|
真 | 真 | 真 |
真 | 假 | 假 |
真 | 不确定 | 不确定 |
假 | 真 | 假 |
假 | 假 | 假 |
假 | 不确定 | 假 |
不确定 | 真 | 不确定 |
不确定 | 假 | 假 |
不确定 | 不确定 | 不确定 |
OR
P | Q | P OR Q |
---|---|---|
真 | 真 | 真 |
真 | 假 | 真 |
真 | 不确定 | 真 |
假 | 真 | 真 |
假 | 假 | 假 |
假 | 不确定 | 不确定 |
不确定 | 真 | 真 |
不确定 | 假 | 不确定 |
不确定 | 不确定 | 不确定 |
3.聚合与排序
3.1 对表进行聚合查询
1.聚合函数(集合函数):计算之前已经将NULL排除在外。
函数 | 含义 |
---|---|
COUNT | 计算表中的记录数(行数) |
SUM | 计算表中数值列中数据的合计值 |
AVG | 计算表中数值列中数据的平均值 |
MAX | 求出表中任意列中数据的最大值 |
MIN | 求出表中任意列中数据的最小值 |
2.COUNT函数的结果根据参数的不同而不同
COUNT(*)包含NULL的数据行数
COUNT(<列名>)NULL之外的数据行数
3.
MAX/MIN函数几乎适用于所有数据类型的列
SUM/AVG只适用于数值类型的列
4.使用聚合函数删除重复值
COUNT( DISTINCT *)
3.2对表进行分组
1.GROUP BY子句
SELECT <列名1>,<列名2>,<列名3>,...
FROM <表明>
GROUP BY <列名1>,<列名2>,<列名3>,...;
聚合键中包含NULL时,在结果中会以"不确定"行(空行)的形式表现出来。
2.与聚合函数和GROUP BY子句有关的常见错误
常见错误①——在SELECT子句中书写了多余的列(MYSQL 支持)
使用聚合函数时,SELECT子句只能存在以下三种元素
- 常数
- 聚合函数
- GROUP BY 子句指定的列名(也就是聚合键)
常见错误②——在GROUP BY子句中写了列的别名
下列语句会发生执行错误:
SELECT product_type AS pt,count(*)
FROM product
GROUP BY pt;
这是因为SQL在DBMS中的执行顺序造成的——SELECT子句在GROUP BY子句之后执行。
常见错误③——GROUP BY子句结果能排序吗
GROUP BY 子句结果的显示是无序的。
常见错误④——在WHERE子句中使用聚合函数
只有SELECT子句和HAVING子句(以及ORDER BY子句)中能够使用聚合函数。
3.3为聚合结果指定条件
1.HAVING子句为集合(组)指定条件。
HAVING可以使用3中要素:
常数
聚合函数
GROUP BY子句中指定的列名(聚合键)
2.相对于HAVING子句,更适合写在WHERE 子句中的条件
聚合键所对应的条件不应写在HAVING子句当中,而应写在WHERE子句中。
原因:
①:WHERE子句 = 指定行所对应的条件;
HAVING子句 = 指定组所对应的条件
②:WHERE执行速度快,使用COUNT函数等对表中数据进行聚合操作时,DBMS内部会进行排序处理,尽可能减少排序的行数,才能增加处理速度。WHERE在排序前过滤,减少了排序行数。HAVING在排序之后进行过滤。
3.4 对查询结果进行排序
1.使用ORDER BY对查询结果进行排序。
2.在ORDER BY 子句中列名的后面使用关键字ASC 可以进行升序排序;使用DESC关键字可以进行降序排序。
3.ORDER BY子句中可以使用多个排序键。
4.排序键包含NULL时,会在开头或末尾进行汇总。
5.在ORDER BY子句中可以使用SELECT子句中定义的别名。这是因为SELECT的执行顺序:
FROM——>WHERE——>GROUP BY ——>HAVING ——>SELECT ——>ORDER BY
6.在ORDER BY子句中可以使用SELECT子句中未使用的列和聚合函数。
SQL基础教程读书笔记-1的更多相关文章
- SQL基础教程读书笔记-2
4 数据更新 4.1数据的插入 1.清单{①列清单 ②值清单列清单和值清单的数量必须保持一致.原则上,执行一次INSERT语句会插入一行数据对表进行全列INSERT时,可以省略表名后的列清单2.插入默 ...
- SQL基础教程读书笔记-3
5 复杂查询 5.1 视图 1.表和视图的区别表:保存的是实际的数据视图:保存的是SELECT语句.从视图读取数据时,视图会在内部执行该SELECT语句并创建出一张临时表. 2.视图的优点① 无需保存 ...
- SQL Server2012 T-SQL基础教程--读书笔记(1-4章)
SQL Server2012 T-SQL基础教程--读书笔记(1-4章) SqlServer T-SQL 示例数据库:点我 Chapter 01 T-SQL 查询和编程背景 1.3 创建表和定义数据的 ...
- SQL Server2012 T-SQL基础教程--读书笔记(8 - 10章)
SQL Server2012 T-SQL基础教程--读书笔记(8 - 10章) 示例数据库:点我 CHAPTER 08 数据修改 8.1 插入数据 8.1.1 INSERT VALUES 语句 8.1 ...
- SQL Server2012 T-SQL基础教程--读书笔记(5-7章)
SQL Server2012 T-SQL基础教程--读书笔记(5-7章) SqlServer T-SQL 示例数据库:点我 Chapter 05 表表达式 5.1 派生表 5.1.1 分配列别名 5. ...
- 【索引】Objective-C基础教程-读书笔记
第1章 启程 http://www.cnblogs.com/duxiuxing/p/5492219.html 第2章 对C的扩展 第3章 面向对象编程的基础知识 第4章 继承 第5章 复合 第6章 ...
- 《Python基础教程读书笔记》
第1章 快速构造:基础知识 1.2交互式构造器 不强制分号,一行就是一行.可以加上分号 1.4数字和表达式 加.减.乘.除.整除.求余.指数.取反(-例如-2**2,**的优先级比-大) from _ ...
- 【Objective-C基础教程-读书笔记】第1章 启程
在第1章里面,作者主要以一种站在世界中心呼唤爱的姿态,给读者们打打鸡血洗洗脑,鼓励大家,投入时间学习Objective-C,值得啊! 首先,Objective-C既能用来开发OS X平台上的APP,又 ...
- Objective-C基础教程读书笔记(6)
第6章 源文件组织 到目前为止,我们讨论过的所有项目都是把源代码统统放入main.m文件中.类的main()函数,@interface和@implementation部分都被塞入同一个文件里.这种结构 ...
随机推荐
- Ionic3 遇到的一些错误- Error: Your isarray platform does not have Api.js
执行:ionic cordova resources android --icon -i 生成应用图标时,出现下面的错误: 尝试解决方案: 删掉整个项目,重新创建,竟然好了....
- AJAX中使用post,get接收发送数据的区别
如何发起请求 xhr.send(); 备注: 如果是get方式,send()命令中不用写任何参数 传递的数据可以写在url中,服务器用$_GEET["参数名"]接收 如果是post ...
- C++ new 解析重载
C++ new 解析重载 new的三种形式: (1)operator new(运算符new) (2)new operator(new 操作) (3)placement new(特殊的new操作)(不分 ...
- 在浏览器里点击input输入框输入,会展示默认的历史下拉菜单
给input设置autocomplete="off"属性可解决此问题
- 脚本检测 media query 分界点
当需要为不同屏幕大小添加不同脚本的时候,首先需要检测对应的media query 是否起效 也就是CSS( @screen only and (min-width: 40em) {})和javascr ...
- 深度学习之seq2seq模型以及Attention机制
RNN,LSTM,seq2seq等模型广泛用于自然语言处理以及回归预测,本期详解seq2seq模型以及attention机制的原理以及在回归预测方向的运用. 1. seq2seq模型介绍 seq2se ...
- C#读取数据库返回泛型集合(DataSetToList)
一般我们用使用ADO.NET查询数据库返回泛型集合使用SqlDataReader逐行读取数据存入对象 代码 }
- 初生牛犊不怕虎 golang入坑系列
读前必读,下面所有内容都是来自这里. 放到这里的目的,就是为了比对一下,哪里的读者多.平心而论,同样的Markdown,博客园排版真心X看,怎么瞅怎么X看.(X := '难' || X :='耐' | ...
- Python进阶---面向对象的程序设计思想
Python的面向对象 一.面向过程与面向对象的对比 面向过程的程序设计的核心是过程(流水线式思维),过程即解决问题的步骤,面向过程的设计就好比精心设计好一条流水线,考虑周全什么时候处理什么东西. 优 ...
- 73、django之setting配置汇总
前面的随笔中我们经常会改setting配置也经常将一些配置混淆今天主要是将一些常见的配置做一个汇总. setting配置汇总 1.app路径 INSTALLED_APPS = [ 'django.co ...