mysql学习之基础篇07

视图:view

在查询的时候我们经常把查询到的结果当成一张临时表来看,其实view就可以看成一张虚拟表,是表通过某种运算得到的投影

那么如何创建视图?创建视图需要指定视图的列名和列类型吗?

答:不用,它只是一种关系

既然视图只是表的某种查询得到的投影,所以主要步骤在于查询表上,查询到的结果命名为视图就行了。

创建视图的语法很简单:

Create view 视图名

As

Select 语句

举个栗子:我们想查询每个栏目下面商品的平均价格,然后取出平均价格前3高的栏目,应该怎么做?

select cat_id,avg(shop_price)
from goods
group by cat_id
order by avg(shop_price) desc
limit 3;

那我们又想查询每个栏目下面商品的平均价格,然后取出平均价格前3低的栏目,又该怎么做?

其实跟上面的差不多,只不过把排序方式从降序更改为升序:

select cat_id,avg(shop_price)
from goods
group by cat_id
order by avg(shop_price) asc
limit 3;

那我们还想查询平均价格在第三到第五之间的栏目,又该怎么做?

select cat_id,avg(shop_price)
from goods
group by cat_id
order by avg(shop_price) desc
limit 2,5;

其实我们可以发现,在上面的那些查询中,我们都要用到“每个栏目下的平均价格”,这时候就该我们的视图出场了:

我们把“每个栏目下的平均价格”创建成一个视图:

create view result
as
select cat_id,avg(shop_price) as pj from goods group by cat_id;

接下来我们就可以直接对视图进行操作了:

我们来查询平均价格在20到100的栏目:

select * from result where pj between 20 and 100;

那我们来对goods表进行操作看看视图会不会发生变化:

insert into goods
(goods_id,goods_name,cat_id,shop_price)
values
(33,‘金立930浪漫镶钻手机‘,4,1999);

我们来看看result视图发生变化了没:

select * from result;

我们可以看到第4栏目的平均价格减少了

这说明我们对表进行操作会影响由这张表生成的视图。

那我们再看看对视图的操作是否能影响表:

我们修改第四栏目的平均价格试试:

update result set pj=2100 where cat_id=4;

我们可以看到报出了这样一个错误,告诉我们result表不能被修改。

其实从逻辑上也很好理解,我们这个价格是平均价格,修改它的话到底该怎么反馈到goods表?这就产生歧义了,所以我们不能修改它,,增加,删除也是一样的。

那么视图就真的不能被增删改吗?

答:不是,只有它和原表中的字段一一对应,就像数学中的映射那样,我们才能对它进行操作:

举个栗子:先建立一张w表:

create table w(
id int,
name varchar(20)
)engine myisam charset utf8;

然后插入数据:

insert into w
values
(001,‘aaa‘),(002,‘bbb‘),(003,‘ccc‘);

我们可以看到里面有三条数据;

然后我们根据w表生成一张视图叫w1:

create view w1
as
select * from w;

然后我们对视图w1增加数据:

insert into w1
values
(004,‘dddd‘);

我们可以看到程序没有报错,然后我们看看这张视图:

我们发现,里面确实被增加了一条数据;

那我们再看看w表发生了什么变化:

可以看到w表也被增加了一条数据;

然后我们修改视图中的数据:

update w1 set name=‘eeee‘ where id=1;

我们可以看到,视图中的数据被修改了,那看看w表情况如何:

可以看到w表中的数据也被修改了。

删除我就不给大家演示了,也是同样的效果。

这就证明我们是可以通过修改视图来修改表的,前提是我们的字段要一一对应,不能在逻辑上出现歧义。

对于一些简单的视图,它在发挥作用的过程中,并没有建立临时表,而只是把条件存起来,下次来查询,把条件一合并,直接去查表。相比于建立临时表,合并查询语句更加快捷。

那么到底是建立临时表还是保存条件?这就需要用到algorithm 来明确指定了:

Algorithm= merge  合并查询语句

Algorithm=temptable 建立临时表

Algorithm= undefined 未定义,由系统判断。

这么说可能不好理解,我们还是通过一个例子来给大家演示:

我们根据上面的w表生成一张视图,不过我们指定它的类型是合并查询语句:

create Algorithm=merge view w2
as
select * from w where id>2;

然后我们在这张视图中进行查询:

select * from w2 where id<4;

它并没有在内存中生成一张叫w2的临时表,而是把我们的查询条件保存了起来

我们查询到的结果其实相当于就是把两次查询条件合并到一起,跟下面的语句效果是等价的;

select * from w where id<4 and id>2;

以上就是我们对视图的讲解和操作。

原文地址:https://www.cnblogs.com/wanghaoyu666/p/11287265.html

时间: 2024-11-09 03:06:44

mysql学习之基础篇07的相关文章

一步步学习javascript基础篇(3):Object、Function等引用类型

我们在<一步步学习javascript基础篇(1):基本概念>中简单的介绍了五种基本数据类型Undefined.Null.Boolean.Number和String.今天我们主要介绍下复杂数据类型(即引用数据类型) Object类型 我们用的最多的引用类型就属object类型了,一般用来存储和传输数据是再好不过的.然,它的两种创建方式我们是否了解呢? 1.通过构造函数来创建 如: var obj = new Object(); 在js中的引用类型有个非常灵活的用法,可以动态的附加属性和赋值.

渗透学习笔记--基础篇--sql注入(字符型)

环境:dvwa1.7数据库:mysql前置知识:sql语句(Click me)      在进行sql注入前,我们先熟悉熟悉select语句.一.打开我们的sql终端 二.进入之后可以看到有mysql>我们输入sql语句,即可返回我们想要的结果,注意分号哟!我们使用的dvwa,在我们前几章设置的时候,会在数据库中生成一个dvwa的database:这里我们使用它来进行我们的select 语句:(1)使用dvwa数据库use dvwa;(2)在users表里查询用户名为'admin'的所有信息se

iOS系列 基础篇 07 Action动作和输出口

iOS系列 基础篇 07 Action动作和输出口 目录:  1. 前言及案例说明 2. 什么是动作? 3. 什么是输出口? 4. 实战 5. 结尾 1. 前言及案例说明 上篇内容我们学习了标签和按钮,下面呢 我们通过一个具备用户交互功能的工程案例进一步练习这两个控件的使用,以及动作和输出口的控制. 此案例基于上篇内容的界面设计,功能的概念流程如图: 此案例的动作和输出口机制如图: 2. 什么是动作? 动作是为了响应一个控件的事件而定义的方法,类似于.NET中WinForm为控件某一事件添加的动

iOS开发学习笔记:基础篇

iOS开发需要一台Mac电脑.Xcode以及iOS SDK.因为苹果设备都具有自己封闭的环境,所以iOS程序的开发必须在Mac设备上完成(当然,黑苹果应该也是可以的,但就需要花很多的精力去折腾基础环境),Xcode是一个集成开发环境,包括了编辑器.调试.模拟器等等一系列方便开发和部署的工具,iOS SDK则是开发应用所必需,不同的SDK分别对应不同的iOS版本或设备,通常我们需要下载多个iOS SDK以确保我们开发的程序能够在不同版本的iOS上正常运行. 创建新工程 Xcode提供了很多种工程模

Python学习笔记基础篇——总览

Python初识与简介[开篇] Python学习笔记——基础篇[第一周]——变量与赋值.用户交互.条件判断.循环控制.数据类型.文本操作 Python学习笔记——基础篇[第二周]——解释器.字符串.列表.字典.主文件判断.对象 Python学习笔记——基础篇1[第三周]——set集合 Python学习笔记——基础篇2[第三周]——计数器.有序字典.元组.单(双)向队列.深浅拷贝.函数.装饰器 Python学习笔记——基础篇[第四周]——迭代器&生成器.装饰器.递归.算法.正则表达式 Python

MySQL学习笔记-基础入门

MySQL学习笔记

渗透学习笔记--基础篇--sql注入(数字型)

环境:dvwa 1.7数据库:mysql dvwa的安全等级:medium 一.分析和查找注入点(1)知识点回顾如果上一篇有好好读过的同学应该知道,我们上一篇遇到的字符型注入.也即是通过Get或者Post方式传进去的数据被单引号或者双引号包裹住.如果我们想要注入自己的payload(有效载荷)的话,则我们必须先闭合前面的单引号或者双引号,否则我们的数据始终会被当做成字符串来处理. 这种类型的注入点称为字符型注入点. (2)这次我们的把防御等级提升了一个层次,来逐步加强我们手工注入的能力以及开更多

深度学习之基础篇(三)

1.神经网络中损失函数和优化函数的作用 训练出一个网络模型之后如何对模型进行评估?往往是衡量预测值与真实值之间的差异程度,这就是通过损失函数来完成的.另外损失函数也是神经网络中优化的目标函数,神经网络训练或者优化的过程就是最小化损失函数的过程,损失函数越小,说明模型的预测值就越接近真实值,模型的准确性也就越好.那么为了最小化损失函数则需要对网络模型的参数进行更新,确定如何更新参数这时则需要选择合适的优化函数(用以确定对网络模型参数进行更新的方法,步长和方向的确定).我们都知道,神经网络模型训练得

Python学习笔记——基础篇【第六周】——面向对象

Python之路,Day6 - 面向对象学习 本节内容: 面向对象编程介绍 为什么要用面向对象进行开发? 面向对象的特性:封装.继承.多态 类.方法. 面向对象编程(Object-Oriented Programming )介绍 对于编程语言的初学者来讲,OOP不是一个很容易理解的编程方式,大家虽然都按老师讲的都知道OOP的三大特性是继承.封装.多态,并且大家也 都知道了如何定义类.方法等面向对象的常用语法,但是一到真正写程序的时候,还是很多人喜欢用函数式编程来写代码,特别是初学者,很容易陷入一