[SQL基础教程] 5-1视图

时间:2022-09-04 17:48:49

[SQL基础教程] 5-1视图

视图和表

从SQL角度看视图就是一张表

视图与表的差别

  • 表保存了实际的数据,视图保存的是SELECT语句;

视图的优点

  • 节省存储空间;
  • 将常用的Select 语句保存成视图。

视图中的数据会随着原表中数据变化而更新。

创建视图

CREATE VIEW 视图名称(<视图列名1>,<视图列名2>,<视图列名3>...)
AS
SELECT语句

视图就是保存好的SELECT语句

基于视图的SELECT查询语句

SELECT a,b
FROM view;

执行顺序:

  1. 执行定义视图的SELECT语句;
  2. 执行SELECT语句

避免在视图的基础上创建视图。

视图的限制

定义视图时不能使用ORDER BY子句;

视图更新

使用聚合语句创建的视图不能进行更新

视图更新的原则是要保持视图和原表的数据一致性。

视图与表的更新,影响都是双向的,更新视图同样会导致表的更新。

删除视图

DROP VIEW view_name;

[SQL基础教程] 5-1视图的更多相关文章

  1. 《SQL基础教程》&plus; 《SQL进阶教程》 学习笔记

    写在前面:本文主要注重 SQL 的理论.主流覆盖的功能范围及其基本语法/用法.至于详细的 SQL 语法/用法,因为每家 DBMS 都有些许不同,我会在以后专门介绍某款DBMS(例如 PostgreSQ ...

  2. &lbrack;SQL基础教程&rsqb; 4-4 事务

    [SQL基础教程] 4 数据更新 4-4 事务 事务 需要在同一处理单元中执行的一系列更新处理的集合 创建事务 事务开始语句; DML语句1; DML语句2; . . . 事务结束语句; 事务开始语句 ...

  3. &lbrack;SQL基础教程&rsqb; 4-3 数据的更新&lpar;UPDATE&rpar;

    [SQL基础教程] C4 数据更新 4-3 数据的更新(UPDATE) UPDATE UPDATE <表名> SET <列名> = <表达式>; UPDATE &l ...

  4. &lbrack;SQL基础教程&rsqb; 4-2 数据删除&lpar;DELETE&rpar;

    [SQL基础教程] C4 数据更新 4-2 数据删除(DELETE) DROP TABLE / DELETE DROP TABLE - 完全删除表 DELETE - 仅删除数据,保留表容器 DELET ...

  5. &lbrack;SQL基础教程&rsqb; 4-1 数据的插入&lpar;INSERT&rpar;

    [SQL基础教程] C4 数据更新 4-1 数据的插入(INSERT) INSERT INSERT INTO <表名>(列1,列2...) VALUES(值1,值2...); 清单 用() ...

  6. &lbrack;SQL基础教程&rsqb; 3-4 对查询结果进行排序&sol;ORDER BY

    [SQL基础教程] 3-4 对查询结果进行排序/ORDER BY ORDER BY SELECT <列名1>,<列名2>,<列名2>... FROM ORDER B ...

  7. &lbrack;SQL基础教程&rsqb; 3-3 HAVING

    [SQL基础教程] 3-3 HAVING HAVING子句 SELECT col_1,col_2 FROM table GROUP BY col_1,col_2 HAVING col_1 = '2'; ...

  8. &lbrack;SQL基础教程&rsqb; 3-2 对表进行分组

    [SQL基础教程] 3-2 对表进行分组 GROUP BY SELECT <列名1>,<列名2>,... FROM <表名> GROUP BY <列名1&gt ...

  9. &lbrack;SQL基础教程&rsqb; 3-1 对表进行聚合查询

    [SQL基础教程] 3-1 对表进行聚合查询 聚合函数 用于合计的函数称为聚合函数或者集合函数 COUNT SUM AVG MAX MIN SELECT COUNT(*) FROM table; SE ...

随机推荐

  1. MediaElement 的两种模式

    MediaElement 是一个 UIElement,它受 布局系统 支持并可用作许多控件的内容.它也可用在可扩展应用程序标记语言 (XAML) 以及代码中.另一方面,MediaPlayer 用于 D ...

  2. map 和 vector 的erase函数说明

    1. map的erase函数使用 这里首先要注意,C++针对map的erase函数有不同的函数原型,这往往是出现问题的关键所在.根据参考文献1: 在C++98中: (1) void erase (it ...

  3. docker-5 docker仓库

    docker部署环境:CentOS release 6.5 (Final) Docker配置文件:/etc/sysconfig/docker  重要参数解释: -H 表示Docker Daemon绑定 ...

  4. SQL查询效率:100w数据查询只需要1秒钟

    G os: windows 数据库: ms sql server 目的: 查询性能测试,比较两种查询的性能 SQL查询效率 step by step -- setp . -- 建表 create ta ...

  5. windows端加密程序,lua代码,ZeroBrane调试

    发一个自己改的zerobrane版本(启动中文,快捷键改成和一样:F5启动调试,F9断点,F10逐过程,F11逐语句,F12跳出函数) 在zerobrane 1.0(2015.3.13)发布的基础上改 ...

  6. MySQL 子查询 EXISTS 和 NOT EXISTS&lpar;转&rpar;

    MySQL EXISTS 和 NOT EXISTS 子查询 MySQL EXISTS 和 NOT EXISTS 子查询语法如下: SELECT ... FROM table WHERE EXISTS ...

  7. 欧几里得旅行商问题 java与c&plus;&plus;实现

    双调欧几里得旅行商问题是一个经典动态规划问题.<算法导论(第二版)>思考题15-1 旅行商问题描述:平面上n个点,确定一条连接各点的最短闭合旅程.这个解的一般形式为NP的(在多项式时间内可 ...

  8. 武汉科技大学ACM:1003&colon; 华科版C语言程序设计教程(第二版)例题6&period;6&period;改编

    Problem Description 小明明最喜欢学英语了,英语课从来不翘课,但是英语却一直没学好,因为上课一直在睡觉.为什么会睡觉呢,因为他觉得英文单词太长了.现在小明明有一个很长很长很长的单词, ...

  9. SDOI&lpar;队列&rpar;

    SDOI Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others) Total Sub ...

  10. 【Java】Android EditText开发的一个容易忽略的坑

    这几天接手做一个远程控制Android application,安卓前台的EditText用来输入ip地址.端口等信息,发现EditText的使用存在着巨坑一个! 我在网上找了半天,发现仅仅有人提出这 ...