《 Oracle查询优化改写 技巧与案例 》电子工业出版社
第1章单表查询 1
1.1 查询表中所有的行与列 1
1.2 从表中检索部分行 2
1.3 查找空值 3
1.4 将空值转换为实际值 4
1.5 查找满足多个条件的行 5
1.6 从表中检索部分列 6
1.7 为列取有意义的名称 6
1.8 在WHERE子句中引用取别名的列 7
1.9 拼接列 7
1.10 在SELECT语句中使用条件逻辑 8
1.11 限制返回的行数 10
1.12 从表中随机返回n条记录 10
1.13 模糊查询 12
第2章给查询结果排序 14
2.1 以指定的次序返回查询结果 14
2.2 按多个字段排序 16
2.3 按子串排序 16
2.4 TRANSLATE 17
2.5 按数字和字母混合字符串中的字母排序 19
2.6 处理排序空值 20
2.7 根据条件取不同列中的值来排序 21
第3章操作多个表 23
3.1 UNION ALL与空字符串 23
3.2 UNION与OR 24
3.3 组合相关的行 31
3.4 IN、EXISTS和INNER JOIN 31
3.5 INNER JOIN、LEFT JOIN、RIGHT JOIN和FULL JOIN解析 34
3.6 自关联 37
3.7 NOT IN、NOT EXISTS和LEFT JOIN 38
3.8 外连接中的条件不要乱放 41
3.9 检测两个表中的数据及对应数据的条数是否相同 45
3.10 聚集与内连接 46
3.11 聚集与外连接 50
3.12 从多个表中返回丢失的数据 50
3.13 多表查询时的空值处理 53
第4章插入、更新与删除 55
4.1 插入新记录 55
4.2 阻止对某几列插入 56
4.3 复制表的定义及数据 57
4.4 用WITH CHECK OPTION限制数据录入 57
4.5 多表插入语句 58
4.6 用其他表中的值更新 62
4.7 合并记录 67
4.8 删除违反参照完整性的记录 70
4.9 删除名称重复的记录 71
第5章使用字符串 74
5.1 遍历字符串 74
5.2 字符串文字中包含引号 76
5.3 计算字符在字符串中出现的次数 77
5.4 从字符串中删除不需要的字符 78
5.5 将字符和数字数据分离 79
5.6 查询只包含字母或数字型的数据 80
5.7 提取姓名的大写首字母缩写 85
5.8按字符串中的数值排序 87
5.9根据表中的行创建一个分隔列表 88
5.10提取第n个分隔的子串 88
5.11分解IP地址 90
5.12将分隔数据转换为多值IN列表 90
5.13按字母顺序排列字符串 91
5.14判别可作为数值的字符串 94
第6章使用数字 100
6.1 常用聚集函数 100
6.2 生成累计和 102
6.3 计算累计差 106
6.4 更改累计和的值 108
6.5 返回各部门工资排名前三位的员工 110
6.6 计算出现次数最多的值 111
6.7 返回最值所在行数据 113
6.8 first_value 116
6.9 求总和的百分比 119
第7章日期运算 122
7.1 加减日、月、年 122
7.2 加减时、分、秒 123
7.3 日期间隔之时、分、秒 124
7.4 日期间隔之日、月、年 124
7.5 确定两个日期之间的工作天数 124
7.6 计算一年中周内各日期的次数 127
7.7 确定当前记录和下一条记录之间相差的天数 129
第8章日期操作 131
8.1 SYSDATE能得到的信息 131
8.2 INTERVAL 134
8.3 EXTRACT 135
8.4 确定一年是否为闰年 137
8.5 周的计算 138
8.6 确定一年内属于周内某一天的所有日期 139
8.7 确定某月内第一个和最后一个“周内某天”的日期 140
8.8 创建本月日历 141
8.9 全年日历 142
8.10 确定指定年份季度的开始日期和结束日期 145
8.11 补充范围内丢失的值 145
8.12 按照给定的时间单位进行查找 147
8.13 使用日期的特殊部分比较记录 148
8.14 识别重叠的日期范围 149
8.15 按指定间隔汇总数据 152
第9章范围处理 155
9.1 定位连续值的范围 155
9.2 查找同一组或分区中行之间的差 157
9.3 定位连续值范围的开始点和结束点 159
9.4 合并时间段 164
第10章高级查找 168
10.1 给结果集分页 168
10.2 重新生成房间号 170
10.3 跳过表中n行 173
10.4 排列组合去重 174
10.5 找到包含最大值和最小值的记录 176
第11章报表和数据仓库运算 179
11.1 行转列 179
11.2 列转行 184
11.3 将结果集反向转置为一列 188
11.4 抑制结果集中的重复值 190
11.5 利用“行转列”进行计算 191
11.6 给数据分组 192
11.7 对数据分组 195
11.8 计算简单的小计 195
11.9 判别非小计的行 198
11.10 计算所有表达式组合的小计 201
11.11 人员在工作间的分布 203
11.12 创建稀疏矩阵 204
11.13 对不同组/分区同时实现聚集 208
11.14 对移动范围的值进行聚集 209
11.15 常用分析函数开窗讲解 212
11.16 listagg与小九九 215
第12章分层查询 217
12.1 简单的树形查询 217
12.2 根节点、分支节点、叶子节点 218
12.3 sys_connect_by_path 219
12.4树形查询中的排序 220
12.5树形查询中的WHERE 221
12.6查询树形的一个分支 222
12.7剪去一个分支 223
12.8字段内list值去重 224
第13章应用案例实现 227
13.1 从不固定位置提取字符串的元素 227
13.2 搜索字母数字混合的字符串 230
13.3 把结果分级并转为列 230
13.4 构建基础数据的重要性 234
13.5 根据传入条件返回不同列中的数据 235
13.6 拆分字符串进行连接 237
13.7 整理垃圾数据 238
13.8 用“行转列”来得到隐含信息 243
13.9 用隐藏数据进行行转列 245
13.10 用正则表达式提取clob里的文本格式记录集 247
第14章改写调优案例分享 249
14.1 为什么不建议使用标量子查询 249
14.2 用LEFT JOIN优化标量子查询 252
14.3 用LEFT JOIN优化标量子查询之聚合改写 252
14.4 用LEFT JOIN及行转列优化标量子查询 255
14.5 标量中有ROWNUM =1 257
14.6 不等连接的标量子查询改写(一) 259
14.7 不等连接的标量子查询改写(二) 262
14.8 标量子查询与改写逻辑的一致性 267
14.9 用分析函数优化标量子查询(一) 269
14.10 用分析函数优化标量子查询(二) 271
14.11 用分析函数优化标量子查询(三) 274
14.12 用分析函数优化标量子查询(四) 277
14.13 用MERGE改写优化UPDATE 281
14.14 用MERGE改写有聚合操作的UPDATE(一) 283
14.15 用MERGE改写有聚合操作的UPDATE(二) 286
14.16 用MERGE改写UPDATE之多个子查询(一) 287
14.17 用MERGE改写UPDATE之多个子查询(二) 288
14.18 UPDATE改写为MERGE时遇到的问题 291
14.19 整理优化分页语句 294
14.20 让分页语句走正确的PLAN 296
14.21 去掉分页查询中的DISTINCT 297
14.22 用WITH语句减少自关联 300
14.23 用WITH改写优化查询 303
14.24 用WITH把OR改为UNION 308
14.25 错误的WITH改写 312
14.26 错误的分析函数用法 315
14.27 用LEFT JOIN优化多个子查询(一) 317
14.28 用LEFT JOIN优化多个子查询(二) 320
14.29 用LEFT JOIN优化多个子查询(三) 322
14.30 去掉EXISTS引起的FILTER 324
14.31 重叠时间计数 325
14.32 用分析函数改写优化 328
14.33 相等集合之零件供应商 334
14.34 相等集合之飞机棚与飞行员 335
14.35 用分析函数改写最值过滤条件 338
14.36 用树形查询找指定级别的数据 339
14.37 行转列与列转行 340
14.38 UPDATE、ROW_NUMBER与MERGE 343
14.39 改写优化UPDATE语句 345
14.40 改写优化UNION ALL语句 347
14.41 纠结的MERGE语句 349
14.42 用CASE WHEN去掉UNION ALL 351
14.43 不恰当的WITH及标量子查询 364
14.44 用分析函数加“行转列”来优化标量子查询 366
14.45 用分析函数处理问题 369
14.46 用列转行改写A表多列关联B表同列 372
14.47 用分析函数改写最值语句 375
14.48 多列关联的半连接与索引 377
14.49 巧用分析函数优化自关联 378
14.50 纠结的UPDATE语句 383
14.51 巧用JOIN条件合并UNION ALL语句 385
14.52 用分析函数去掉NOT IN 388
14.53 读懂查询中的需求之裁剪语句 392
14.54 去掉FILTER里的EXISTS之活学活用 393
《 Oracle查询优化改写 技巧与案例 》电子工业出版社的更多相关文章
- 《Oracle查询优化改写技巧与案例》学习笔记-------使用数字篇
一个系列的读书笔记,读的书是有教无类和落落两位老师编写的<Oracle查询优化改写技巧与案例>. 用这个系列的读书笔记来督促自己学习Oracle,同时,对于其中一些内容,希望大家看到以后, ...
- 2016.9.9《Oracle查询优化改写技巧与案例》电子工业出版社一书中的技巧
1.coalesce (c1,c2,c3,c4,...) 类似于nvl但可以从多个表达式中返回第一个不是null的值 2.要在where条件中引用列的别名,可以再嵌套一层查询 select * fro ...
- 【书评:Oracle查询优化改写】第四章
[书评:Oracle查询优化改写]第四章 BLOG文档结构图 一.1 导读 各位技术爱好者,看完本文后,你可以掌握如下的技能,也可以学到一些其它你所不知道的知识,~O(∩_∩)O~: ① check的 ...
- 【书评:Oracle查询优化改写】第14章 结尾章
[书评:Oracle查询优化改写]第14章 结尾章 一.1 相关参考文章链接 前13章的链接参考相关连接: [书评:Oracle查询优化改写]第一章 http://blog.itpub.net/26 ...
- 【书评:Oracle查询优化改写】第五至十三章
[书评:Oracle查询优化改写]第五至十三章 一.1 BLOG文档结构图 一.2 前言部分 一.2.1 导读 各位技术爱好者,看完本文后,你可以掌握如下的技能,也可以学到一些其它你所不知道的知 ...
- oracle 查询优化改写
-----------书籍: oracle 查询优化改写-----------第1个“C###oracle”为登录数据库的用户名,第2个“oracleChange”为登录数据库的密码“oracleCh ...
- 【书评:Oracle查询优化改写】第三章
[书评:Oracle查询优化改写]第三章 BLOG文档结构图 导读 各位技术爱好者,看完本文后,你可以掌握如下的技能,也可以学到一些其它你所不知道的知识,~O(∩_∩)O~: ① 隐含参数 ...
- 【书评:Oracle查询优化改写】第二章
[书评:Oracle查询优化改写]第二章 BLOG文档结构图 在上一篇中http://blog.itpub.net/26736162/viewspace-1652985/,我们主要分析了一些单表查询的 ...
- 郑捷2017年电子工业出版社出版的图书《NLP汉语自然语言处理原理与实践》
郑捷2017年电子工业出版社出版的图书<NLP汉语自然语言处理原理与实践> 第1章 中文语言的机器处理 1 1.1 历史回顾 2 1.1.1 从科幻到现实 2 1.1.2 早期的探索 3 ...
随机推荐
- datatable转换为list<model> 映射
using System; using System.Collections.Generic; using System.Data; using System.Linq; using System.R ...
- java并发基础
一.创建线程 1.使用Executor:java.util.concurrent包中的执行器(Execute)为你管理Thread对象,从而简化并发编程. package thread; import ...
- WSGI、uwsgi和uWSGI
一.WSGI WSGI ( Web Server Gateway Interface )是一个网络服务器和网络应用的通用接口的规范或者用于Python框架. 由于python开发人员在网络框架的选择限 ...
- mysql原理~创建用户的那些事情
一 简介:mysql是如何创建用户的二 基本语法: 1 grant 权限 on db.table to 'user'@'ip' identified by 'password' 目的 创建用 ...
- mongodb 案例 ~ 经典故障案例
一 简介:此文汇总遇到过和搜集过的故障案例 二 场景案例 1 问题描述: mongo集群在无任何业务情况下,mongos所在服务器cpu突然被打满,内核日志报错 mongos被hung住,非常奇怪的问 ...
- centOS7 tomcat 开机自启 自启动设置
1.编写配置文件 // (1)修改tomcat.service vim /lib/systemd/system/tomcat.service // (2)复制以下代码,注意修改tomcat路径 [Un ...
- 刷题之路第三题--Longest Substring Without Repeating Characters
问题简介:求给定字符串中最长的字符不重复的字符串的长度 问题详解: 给定一个字符串,寻找给定字符串中包含的最长的字符不重复的字符串的长度 注:答案必须是子字符串,不是子序列 是连续的字符不重复的字符串 ...
- Python写一个京东抢券脚本
最近看到京东图书每天有优惠券发放,满200减100,诱惑还是蛮大的.反正自己抢不到,想着写个脚本试试. 几个关键步骤 获取优惠券的url 直接审查元素 获取cookie 通过本地代理,比如BurpSu ...
- canves绘制北京地铁线路图,包括线路绘制,优先路线,单路径选择。
canves绘制北京地铁线路图,包括线路绘制,优先路线,单路径选择. 即将推出,后台涵盖各种语言,php,C#,java,nodejs等.
- 最近邻算法(KNN)
最近邻算法: 1.什么是最近邻是什么? kNN算法全程是k-最近邻算法(k-Nearest Neighbor) kNN算法的核心思想是如果一个样本在特征空间中的k个最相邻的样本中的大多数数以一个类型别 ...