本文目录一览:
mysql 视图
1、什么是视图
视图:MySQL从5.0.1版本开始提供视图功能。一种虚拟存在的表,行和列的数据来自定义视图的查询中使用的表,并且是在使用视图时动态生成的,只保存了sql逻辑,不保存查询结果
2、视图应用场景
多个地方用到同样的查询结果该查询结果使用的sql语句较复杂
4、视图的好处
使用简单安全数据独立
5、创建或者修 改视图
创建视图的语法:
修改视图的语法
6、视图更新性
视图的可更新性和视图中查询的定义有关系,以下类型的视图是不能更新的。(1)包含以下关键字的sql语句:分组函数、distinct、group by、having、union或者union all(2)常量视图(3)Select中包含子查询(4)join(5)from一个不能更新的视图(6)where子句的子查询引用了from子句中的表
7、删除视图的语法
用户可以一次删除一个或者多个视图,前提是必须有该视图的drop权限。
8、查看视图结构的语法
show tables;如果需要查询某个视图的定义,可以使用show create view命令进行查看
MySQL视图
使用示例
使用示例
使用示例
检查选项的使用
mysql是可以基于视图创建视图,它会检查视图所依赖的视图的规则
如果再基于v2创建视图v3,v3没有定义检查选项,则此时向v3中插入数据时,不会检查是否满足v3的条件,但是会检查是否满足v2和v1的条件
local选项相比于cascaded,不会自动向上添加选项
如创建一个视图,此时视图中只包含一条数据
例如,现要查询每个学生选修的课程(多对多,三张表),将SQL保存到视图,以后再想查询,直接select * from 视图即可
怎么知道mysql 里是表还是视图??
show full tables from 数据库名 [like 'pattern']
"[]"表示可选的, like后面跟的是表名的模糊查询,.
举例:
一个视图的名字叫v_user, SQL语句可以写为show full tables from 数据库名 like '%v_user%';
mysql 如何查看视图
1) mysql show table status where comment='view';
(说明:Mysql5.1支持视图,视图被看作一种抽象表,因此显示视图状态的语句与显示表状态的语句相同,只是在comment列中以‘view’区分)
2) mysql select * from information_schema.tables where table_schema='yourDatabaseName' and table_type='view';
(说明:这种方法通过系统表查找,效果同上,显示信息更详细。如果不能正确显示结果,可能是大小写的问题,Mysql在不同系统平台不同配置参数下的显示结果可能不同,注意这点。)
如何判断mysql 中视图是否存在?
可以通过select查询视图的方式,来判断视图是否存在。
--1.假设现在新建一个视图
create or replace force view test_view as
select * from dept;
--2.通过count(1)查出来的是,该视图中记录的总条数
select count(1) from test_view;
--3.如果要判断该视图是否存在,直接查看该视图中的内容即可
select * from test_view;
-- 如果有字段等内容,说明视图是存在的。反之,无法成功编译,因为视图不存在。
mysql查看数据库是否有视图
MySql软件本身没有视图化查询界面,但是可以借助第三方软件实现,比如:Navicat等。