SQL入门学习4-复杂查询
5-1 视图
视图和表
视图和表的区别只有一个是否保存了实际的数据
使用INSERT和SELECT实际上就是从存储设备中读取数据,各种计算后,将数据呈现给用户。
视图不会将数据保存在存储设备中。实际上,视图保存的是SELECT语句视图会在内部执行该SELECT并创建出一张临时表。
视图的优点
- 无需保存数据,节省存储设备的容量。
- 可以将频繁使用的SELECT保存成视图,这样就不用每次都重新书写了。
创建视图
创建视图,要使用CREATE VIEW语句
语法:
CREATE VIEW 视图名称 (<视图列表1>,<视图列表2>,……)
AS
<SELECT语句>
注意:
- SELECT语句需要书写在AS关键字之后,
- SELECT语句中的列的排列顺序和视图中的列的排列顺序相同。
例:
CREATE VIEW myView (age, name)
AS
SELECT age, name
FROM STU
WHERE age>10;
这就完成一个视图的创建,创建成功,会有CREATE VIEW的字样。
之后就可以像用普通表一样去使用这个视图了。
使用视图的查询
实际有两个步骤:
- 执行定义视图的SELECT语句。
- 根据得到的结果,再执行在FROM子句中使用视图的SELECT语句。
多重的视图会降低效率,所以建议使用单重视图。
视图的限制:
- 定义视图时不能使用
ORDER BY子句。
因为视图和表一样,数据都是没有顺序的。 - 限制性对视图进行更新
条件:- SELECT子句中未使用DISTINCT
- FROM子句中只有一张表
- 未使用
GROUP BY子句。 - 未使用
HAVING子句
视图和表需要同时进行更新,因此通过聚合得到的视图无法进行更新
在视图中进行数据的更新, 在原表中,数据也会进行更新。
删除视图
语法:
DROP VIEW 视图名称
例如:
DROP VIEW myView
在PostgreSQL下,如果想删除已视图未寄出创建出来的多重视图,会由于存在关联视图,而发生错误。
可以使用DROP VIEW 视图名 CASCADE进行删除。
5-2 子查询
子查询和视图
子查询就是一张一次性的视图。
例:
SELECT name ,age
FROM (SELECT name, age
FROM STU
WHERE age>10) AS temp;
有种类似嵌套SELECT的感觉。
子查询作为内层查询会首先执行。
增加子查询的层数
子查询的层数原则上没有上限。
标量子查询
标量子查询有一个特殊限制:
必须而且只能返回一行一列的数据
标量子查询就是返回单一值的子查询
使用实例:
当在WHERE时,需要使用类似平均值这种聚合函数,但是会发生错误。如果我们需要使用到标量子查询。
例如:
SELECT *
FROM STU
WHERE score > (SELECT AVG (score)
FROM STU);
使用范围:
任意可以使用单一值的
5-3 关联子查询
- 关联子查询会在细分的组内进行比较时使用
- 关联子查询和GROUP BY子句一样,也可以对表中的数据进行切分。
- 关联子查询的结合条件如果未给出在子查询之中就会发生错误。
使用情况:
对切分后的组进行子查询
SQL入门学习4-复杂查询的更多相关文章
- SQL入门学习2-聚合与排序
3-1 对表进行聚合查询 聚合函数 所谓聚合,就是将多行汇总为一行. 函数名 功能 COUNT 计算表中的记录数(行数) SUM 计算表中数值列的数据合计值 AVG 计算表中数值列的数据平均值 MAX ...
- SQL入门学习1-查询基础
2-1 SELECT语句基础 SELECT语句作用 SELECT 语句用于从表中选取数据. 结果被存储在一个结果表中(称为结果集). 重点 使用SELECT语句从表中选取数据. 为列设定显示用的别名 ...
- SQL入门学习0-数据库与SQL
1.1 DBMS DatabaseManagermentSystem 数据库管理系统 DBMS种类 层次型数据库(HDB) 最古老的数据库之一,把数据通过层次结构的方式表现. 关系型数据库(RDB) ...
- SQL Serever学习9——基础查询语句
SQL语言概述 SQL是结构化查询语言(Structure Query Language),1974年提出,1979年被IBM实现,SQL语言已经成为关系型数据库的标准语言. 包括: DDL数据定义语 ...
- SQList3 and SQL入门学习笔记
SQL 这是一个标准的计算机语言进行访问和操作数据库. 什么是 SQL? · SQL 指结构化查询语言 · SQL 使我们有能力訪问数据库 · SQL 是一种 AN ...
- SQL入门学习5-函数、为此、CASE表达式
6-1. 各种各样的函数 函数的种类 算数函数 字符串函数 日期函数 转换函数 聚合函数 1.1算术函数 数据类型:NUMERIC 是大多数DBMS都支持的一种数据类型. 通过NUMBERIC(全体位 ...
- SQL入门学习3-数据更新
4-1 数据的插入(INSERT语句的使用方法) 使用INSERT语句可以向表中插入数据(行).原则上,INSERT语句背刺执行一行数据插入. CREATE TABLE 和INSERT 语句,都可以设 ...
- Sql入门学习——关系范式
--------关系 --------范式 一.三种关系 1.一对一关系 关系数据库中,第一个表中的单个行只可以与第二个表中的一个行相关,且第二个表中的一个行也只可以与第一个表中的一个行相关. 2.一 ...
- Sql入门学习——基本语法函数
--------使用工具navicat 快捷键操作 --------基本操作DML &DDL --------运算比较 --------数据类型 --------常用函数 --------常用 ...
随机推荐
- HTML contact form with CAPTCHA
http://www.html-form-guide.com/contact-form/html-contact-form-captcha.html#codedownload
- Linux学习笔记——例说makefile 头文件查找路径
0.前言 从学习C语言開始就慢慢開始接触makefile,查阅了非常多的makefile的资料但总感觉没有真正掌握makefile,假设自己动手写一个makefile总认为非常吃力.所以特意借 ...
- POJ 3684 Priest John's Busiest Day 2-SAT+输出路径
强连通算法推断是否满足2-sat,然后反向建图,拓扑排序+染色. 一种选择是从 起点開始,还有一种是终点-持续时间那个点 開始. 若2个婚礼的某2种时间线段相交,则有矛盾,建边. easy出错的地方就 ...
- 数据结构读书笔记(二)(C语言)
(一)循环链表 存储类型 typedef struct LNode { ElemType data; struct LNode *next; }; typedef struct LNode *Link ...
- 重新想象 Windows 8 Store Apps (22) - 文件系统: 访问文件夹和文件, 通过 AQS 搜索本地文件
原文:重新想象 Windows 8 Store Apps (22) - 文件系统: 访问文件夹和文件, 通过 AQS 搜索本地文件 [源码下载] 重新想象 Windows 8 Store Apps ( ...
- [Windows Phone] 以多国语言做为开发前提 (1)
原文:[Windows Phone] 以多国语言做为开发前提 (1) ? 前言 在先前 TechDays 2013 的课程 [开发 Windows Phone 商务应用程式就是这麽快] 中,其中一个部 ...
- MySql语句大全:创建、授权、查询、修改等(转)
林炳文Evankaka原创作品.转载请注明出处http://blog.csdn.net/evankaka 一.用户创建.权限.删除 1.连接MySql操作 连接:mysql -h 主机地址 -u 用户 ...
- 认识Backbone (五)
Backbone.Router(路由)/ Backbone.history(历史) Backbone.Router 为客户端路由提供了许多方法,并能连接到指定的动作(actions)和事件(even ...
- 玩转Web之easyui(三)-----easy ui dataGird 重新指定url以获取不同数据源信息
如果已经写了一个dataGird并且已经通过url绑定数据源,能不能在其他地方改变url使其从不同数据源获取信息,从而实现查询等操作?答案当然是肯定的,而且仅需要几行代码 $('#btnq').bin ...
- 输出A打头的字符串
题目描述 输出n个字符串,把其中以字母A打头的字符串输出. 输入 第一行 n 第二行到第n+1行,每行一个字符串 输出 A打头的字符串 样例输入 3 Ada Bob Alice 样例输出 Ada Al ...