视图

视图:view是一种有结构的但是没有结构来源的虚拟表,虚拟表的结构来源不是自己定义的而是从对应的基表中产生(来源)

创建视图

基本语法:

Create view 视图名字 as select 语句

可以是普通查询,也可以是连接查询,联合查询,子查询。

创建单表视图:

基表只有一个

例:create view my_view as select *from my_class;

创建多表查询

基表有多个

查看视图:

查看视图结构

视图是一张虚拟表,表的查看方式适用于

视图:show tables ,desc 表名

Show create table 表名\G

视图与表还是有一个关键字的区别:view

查看表(视图)的创建语句的时候可以使用view关键字

视图一旦创建:系统就会在视图对应的数据库文件夹下创建一个对应的结构文件:frm文件

使用视图

使用视图:主要是为了子查询:将视图做为表一样

查询:视图的执行:其实本质就是执行封装的select语句

修改视图:

视图本身不可修改,但是视图的来源可以修改

修改视图:修改视图本身的来源语句(select 语句)

Alter view视图名字 as 新的select语句

例:alter view my_view as select id,name,age,sex from my_stu;

删除视图

Drop view 视图名字;

视图的意义

1,视图可以节省sql语句:将一条复杂的查询语句使用视图进行保存,以后可以直接对视图进行操作;

2,数据安全:视图操作是主要针对查询,如果对视图结果进行处理(删除)不会影响基表数据(相对安全)

3,视图往往是在大型项目中使用,而且是多系统使用,对外提供有效有用的数据隐藏关键(无用的)数据,数据安全。

4,视图对外提供友好型,不同的视图提供不同的数据,对外好像是专门设计

5,视图可以更好地进行权限控制

视图数据操作

视图可以进行很多数据写操作:但是有限制,将数据直接在视图上进行操作

新增数据

数据新增直接对数据进行新增

1,多表数据不能进行新增操作

2,可以向单表视图插入数据,但是视图中包含的字段必须有基表所不能为空(或者没有默认值)字段

3,视图可以向基表插入数据(不应该给权限)

删除数据

1,多表视图不能删除数据

2,单表视图可以删除数据(对基表进行操作)‘delete from my_view2 where id=2’

更新数据

理论上单表与多表视图都可以更新数据库

Update my_view1 set id=3 where id=2;

更新限制:with check option 如果对视图在新增的时候,限定了某个字段有限制;那么在对视图进行数据更新操作之后,数据依然可以被实体查询出来,否则不更新。

例:select * from my_stu where age>30 with check option---表视图数据来源年龄不能>30岁,with check option 决定更新的时候不能将age >30改成<30。

视图算法

系统对视图以及外部查询视图select语句的一种解析方法。

视图算法有三种

1,undefind:未定义(默认的),这不是实际使用算法,推卸责任的算法告诉系统,视图没有定义算法,自己看着办吧!

2,Temptable:临时算法,系统应该先执行视图的select语句,后执行外部查询语句

3,Merge:合并算法,系统应该先将视图对应的select语句与外部查询视图的select语句进行合并;然后执行(效率高,常态);

算法指定:创建视图的时候

Create algorithm =指定算法 view 视图名字 as select 语句;

视图算法的选择

如果视图的select语句中包含一个查询子句(五子句???)而且很有肯比外部查询语句要靠后,一定要使用temptable 其他情况不指定。

mysql学习之路_视图的更多相关文章

  1. mysql学习之路_事物_存储过程_备份

    数据备份与还原 备份:将当前已有的数据保留. 还原:将已经保留的数据恢复到对应表中 为什么要做数据备份 1,防止数据丢失,被盗,误操作 2,保护数据记录 数据备份还原方式有多种:数据表备份 单表数据备 ...

  2. mysql学习之路_基础知识

                    Mysql php阶段将数据库分为三个阶 基础阶段: mysql数据库的基本操作(增删改查),以及一些高级操作(视图,触发器,函数,存储过程等),PHP操作没有sql数 ...

  3. mysql学习之路_联合查询与子查询

    联合查询 联合查询:将多次查询(多条select语句)在记录上进行拼接(字段不会增加). 语法:多条select语句构成,每条select语句获取的字段必须严格一致(但是字段类型无关). Select ...

  4. mysql学习之路_外键

    回顾4 连接查询: 连接多张表到一起,不管记录数如何,字段数一定会增加. 分类:内连接,外连接.自然连接,交叉连接, 交叉连接:cross join (笛卡尔积) 内连接:inner join,左右两 ...

  5. mysql学习之路_高级数据操作

    关系 将实体与实体的关系,反应到最终数据表的设计上来,将关系分为三种,一对多,多对多,多对多. 所有关系都是表与表之间的关系. 一对一: 一张表的一条记录一定只对应另外一张表的一条记录,反之亦然. 例 ...

  6. mysql学习之路_字段类型与属性2

    字段属性: 主键,唯一键,自增长. 主键: Primary key 主要的键,一张表只能有一个字段能使用对应的键,用来唯一约束该字段里面的数据不能重复,称之为主见. 一张表最多只有一个主键. 增加主键 ...

  7. mysql学习之路_字段类型与属性

    回顾 数据库基本知识:关系型数据库与非关系型数据库 关系型数据库:安全(磁盘) 非关系型数据库:高效(内存) 关系型数据库:建立在关系模型上的数据库, 数据结构:二维表(浪费空间) 数据库操作指令:s ...

  8. mysql学习之路_连接查询

    回顾 列属性:主键,自增长,唯一键. 关系:一对一,一对多,多对多 三层范式: 1NF:字段设计必须符合原子性 2NF:不存在部分依赖(没有复合主键) 3NF:不存在传递依赖(实体单独成表) 逆规范化 ...

  9. mysql学习之路_乱码问题

    中文数据问题: 中文数据问题本质就说字符集问题, 计算机只识别二进制,人类识别符号:需要友谊个二进制与字符对应关系(字符集). 报错:服务器没有识别对应的四个字节. 服务器认为的数据是utf—8,一个 ...

随机推荐

  1. Django的CBV的学习

    之前我们在路由匹配的时候,一个url对应一个函数,其实我们还可以一个url对应一个类,这个就是CBV,下面我们来简单的介绍一下CBV 一.CBV的基本用法 1.在路由匹配中要这样写,class_log ...

  2. swift - xcode10 - 点击事件交互BUG - (手势和button的addTarget方法)

    1. 现象button 点击闪退:没有任何原因 ,在听云检测上,显示 BUG2: 手势 没有任何作用,哪怕设置  isUserInteractionEnabled 和isEnabled 为true 都 ...

  3. IntelliJ+Maven+Spring+Tomcat项目搭建(MAC)

    1.新建项目 打开idea,通过File->new->project,会弹出如下的信息: 接下来点击下一步,创建项目,点击“下一步”: 选择默认的Maven以及setting文件,点击“下 ...

  4. 通过docker-compose构建ghost博客(一)

    通过命令构建ghost博客 docker run -d --name ghost -p : -v $PWD/data:/var/lib/ghost ghost 当然也可以编写yml文件,通过docke ...

  5. 安装opencv2.4.9

    首先如果你的运气足够好,你完全可以按照 : https://my.oschina.net/u/1757926/blog/293976 或者OpenCV中文论坛上的Linux下opencv的安装方法 但 ...

  6. pyton random 模块

    import random print(random.random())#(0,1)----float 大于0且小于1之间的小数 print(random.randint(1,3)) #[1,3] 大 ...

  7. 4K - 找新朋友

    新年快到了,“猪头帮协会”准备搞一个聚会,已经知道现有会员N人,把会员从1到N编号,其中会长的号码是N号,凡是和会长是老朋友的,那么该会员的号码肯定和N有大于1的公约数,否则都是新朋友,现在会长想知道 ...

  8. 分析params_s方法

    /** * 解析启动模式参数 * @param $opt */ static public function params_s($opt) { //判断传入了s参数但是值,则提示错误 if ((iss ...

  9. UI设计教程分享:6个不能错过的UI设计网站

    Ui设计学习的人越来越多了,想要找到合适的学习资料很难,很多才接触ui设计且没有基础的同学也不知道去哪里找学习资料,虽然现在百度上很容易搜到ui设计的学习资料,但是一看不难发现,很多都是过时的学习资料 ...

  10. Linux中处理字符串

    获取字符串长度: ${#字符串变量名} 截取子串: 1. expr substr 字符串 起始位置 截取长度 2. 命令输出 | cut -c 起始位置-结束位置 命令输出 | cut -c &quo ...