精华内容
下载资源
问答
  • 行和列数据来自由定义视图的查询所引用表。 2、视图作用 (1)简化用户操作 关键信息来源于多个复杂关联表,可以创建视图提取我们需要信息, 简化操作; (2)对机密数据提供保护作用 不希望用户访问表...

    1、什么是视图
    视图就是一条SELECT语句执行后返回的结果集,
    视图是一个虚拟表,同真实的表一样,视图包含一系列带有名称的列和行数据。但是,视图并不在数据库中以存储的数据值集形式存在。行和列数据来自由定义视图的查询所引用的表。
    2、视图作用
    (1)简化用户的操作
    关键信息来源于多个复杂关联表,可以创建视图提取我们需要的信息,
    简化操作;

    (2)对机密数据提供保护作用
    不希望用户访问表中某些含敏感信息的列,比如salary…
    3、操作视图
    (1)创建视图:
    Create view 视图名称 as DQL语句(select …);
    (2)删除视图:
    Drop view 视图名称;
    练习
    有 t_employee和 t_employee_detail 表格
    t_employee 表格:

    CREATE TABLE t_employee(
            ID INT  PRIMARY KEY  AUTO_INCREMENT,
            NAME CHAR(30) NOT NULL,
            GENDER  CHAR(2) NOT NULL,
            AGE INT NOT NULL,
            DEPARTMENT CHAR(10) NOT NULL,
            SALARY  INT NOT NULL,
            HOME CHAR(30),
            MARRY CHAR(2) NOT NULL DEFAULT  '否',       
            HOBBY CHAR(30)
     );
    

    t_employee_detail 表格:

    create TABLE t_employee_detail(
    ID INT PRIMARY KEY,
    POS CHAR(10) NOT NULL,
    EXPERENCE CHAR(10) NOT NULL,
    CONSTRAINT `FK_ID` FOREIGN KEY(ID) REFERENCES t_employee(ID)
    )
    
    INSERT INTO t_employee(NAME, GENDER, AGE,DEPARTMENT, SALARY, HOME, MARRY, HOBBY) VALUES('张飞','女',21,'人事部','9000','北京','否','网球');
    
    INSERT INTO t_employee(NAME, GENDER, AGE,DEPARTMENT, SALARY, HOME, MARRY, HOBBY) VALUES('刘备','男',22,'研发部','8000','上海','否','音乐');
    
    INSERT INTO t_employee(NAME, GENDER, AGE,DEPARTMENT, SALARY, HOME, MARRY, HOBBY) VALUES('关羽','女',23,'研发部','9000','重庆','否','无');
    
    INSERT INTO t_employee(NAME, GENDER, AGE,DEPARTMENT, SALARY, HOME, MARRY, HOBBY) VALUES('马超','女',24,'研发部','9000','四川','是','足球');
    
    INSERT INTO t_employee(NAME, GENDER, AGE,DEPARTMENT, SALARY, HOME, MARRY, HOBBY) VALUES('赵云','男',25,'销售部','6000','福建','否','游戏');
    
    INSERT INTO t_employee(NAME, GENDER, AGE,DEPARTMENT, SALARY, HOME, MARRY, HOBBY) VALUES('诸葛亮','女',26,'销售部','5000','山西','否','篮球');
    
    INSERT INTO t_employee_detail(ID,POS,EXPERENCE) VALUES(1,'人事管理','工作二年');
    
    INSERT INTO t_employee_detail(ID,POS,EXPERENCE) VALUES(2,'人事招聘','工作二年');
    
    INSERT INTO t_employee_detail(ID,POS,EXPERENCE) VALUES(3,'初级工程师','工作一年');
    
    INSERT INTO t_employee_detail(ID,POS,EXPERENCE) VALUES(4,'中级工程师','工作二年');
    
    INSERT INTO t_employee_detail(ID,POS,EXPERENCE) VALUES(5,'高级工程师','工作三年');
    
    INSERT INTO t_employee_detail(ID,POS,EXPERENCE) VALUES(6,'销售代表','工作二年');
    

    练习1: 创建一个员工基本信息的视图。

    -- 查看表格中的所有数据
    select * from t_employee;
    -- 查看表格中员工的基本信息。
    select name,gender,age,home,marry,hobby from t_employee;
    -- 创建视图。
    create view v_employee as select name,gender,age,home,marry,hobby from t_employee;
    -- 查看视图中的内容
    select * from v_employee;
    

    练习2:将员工所有的信息做成一个视图。

    -- 查询出所有员工信息
    select * from t_employee as t1 LEFT JOIN t_employee_detail as t2 ON t1.id=t2.id;
    
    -- 去掉 重复的id
    select t1.*,t2.pos,t2.experence from t_employee as t1 LEFT JOIN t_employee_detail as t2 ON t1.id=t2.id;
    
    -- 创建视图
    create view v_employee_detail as select t1.*,t2.pos,t2.experence from t_employee as t1 LEFT JOIN t_employee_detail as t2 ON t1.id=t2.id;
    
    -- 显示所有数据
    select * from v_employee_detail;
    select name,gender,age from v_employee_detail;
    

    4、更新视图
    在MySQL中,更新视图是指通过视图来插入(INSERT)、更新(UPDATE)和删除(DELETE)表中的数据。因为视图是一个虚拟表,其中没有数据,所以通过视图更新时,都是转换到基本表来更新。
    更新视图时,只能更新权限范围内的数据。超出了范围,就不能更新。

    练习1:将张飞性别改成男

    update v_employee_detail set gender ='男' where name='张飞';
    

    注意:对应 的真实表上的数据也发生改变 了

    不可更新的视图:
    某些视图是可更新的。也就是说,可以在诸如UPDATE、DELETE或INSERT等语句中使用它们,以更新基表的内容。对于可更新的视图,在视图中的行和基表中的行之间必须具有一对一的关系。还有一些特定的其他结构,这类结构会使得视图不可更新。更具体地讲,如果视图包含下述结构中的任何一种,那么它就是不可更新的:

    · 聚合函数(SUM(), MIN(), MAX(), COUNT()等)。
    · DISTINCT
    · GROUP BY
    · HAVING
    · UNION
    · 位于选择列表中的子查询
    · Join
    · FROM子句中的不可更新视图
    · WHERE子句中的子查询,引用FROM子句中的表。

    注意
    视图中虽然可以更新数据,但是有很多的限制。一般情况下,最好将视图作为查询数据的虚拟表,而不要通过视图更新数据。因为,使用视图更新数据时,如果没有全面考虑在视图中更新数据的限制,就可能会造成数据更新失败。

    展开全文
  • 视图,虚拟表,从一个表或多个表中导出来表,作用和真实表一样,包含一系列带有行和列数据 视图中,用户可以使用SELECT语句查询数据,也可以使用INSERT,UPDATE,DELETE修改记录,视图可以使用户操作方便,并...

    视图,虚拟表,从一个表或多个表中导出来的表,作用和真实表一样,包含一系列带有行和列的数据 视图中,用户可以使用SELECT语句查询数据,也可以使用INSERT,UPDATE,DELETE修改记录,视图可以使用户操作方便,并保障数据库系统安全

    优点及缺点

    优点

    简单化,数据所见即所得

    安全性,用户只能查询或修改他们所能见到得到的数据

    逻辑独立性,可以屏蔽真实表结构变化带来的影响

    缺点

    性能相对较差,简单的查询也会变得稍显复杂

    修改不方便,特变是复杂的聚合视图基本无法修改

    创建视图语法详解

    语法结构:

    { CREATE|REPLACE } [ALGORITHM = {UNDEFINED | MERGE | TEMPTABLE}]

    VIEW view_name [{column_list}]

    AS SELECT_STATEMENT

    [WITH [CASCADED | LOCAL |] CHECK OPTION]

    释义:

    CREATE|REPLACE : 【创建|替换已创建的】视图

    ALGORITHM : 视图算法

    1.UNDEFINED 系统自动选择算法

    2.MERGE使用的视图语句与视图定义合并起来

    3.TEMPTABLE 结果存入临时表,然后用临时表执行语句

    view_name : 视图名称

    column_list : 属性列

    SELECT_STATEMENT :SELECT语句

    [WITH [CASCADED | LOCAL |] CHECK OPTION] 表示视图在更新时保证在视图的权限范围内

    1.CASCADED 默认值 更新视图时要满足所有相关视图和表的条件,2.LOCAL表示更新视图时满足该视图本身定义的条件即可。

    示例用表

    测试表:user有id,name,age,sex字段

    测试表:goods有id,name,price字段

    测试表:ug有id,userid,goodsid字段

    视图的作用实在是太强大了,以下是我体验过的好处:

    作用一:

    提高了重用性,就像一个函数。如果要频繁获取user的name和goods的name。就应该使用以下sql语言。示例:

    1 select a.name as username, b.name as goodsname from user as a, goods as b, ug as c where a.id=c.userid and c.goodsid=b.id;

    但有了视图就不一样了,创建视图other。示例

    1 create view other as select a.name as username, b.name as goodsname from user as a, goods as b, ug as c where a.id=c.userid and c.goodsid=b.id;

    创建好视图后,就可以这样获取user的name和goods的name。示例:

    select * from other;

    以上sql语句,就能获取user的name和goods的name了。

    作用二:

    对数据库重构,却不影响程序的运行。假如因为某种需求,需要将user拆分为表usera和表userb,该两张表的结构如下:

    测试表:usera有id,name,age字段

    测试表:userb有id,name,sex字段

    这时如果php端使用sql语句:select * from user;那就会提示该表不存在,这时该如何解决呢。解决方案:创建视图。以下sql语句创建视图:

    1 create view user as select a.name,a.age,b.sex from usera as a, userb as b where a.name=b.name;

    以上假设name都是唯一的。此时php端使用sql语句:select * from user;就不会报错什么的。这就实现了更改数据库结构,不更改脚本程序的功能了。

    作用三:

    提高了安全性能。可以对不同的用户,设定不同的视图。例如:某用户只能获取user表的name和age数据,不能获取sex数据。则可以这样创建视图。示例如下:

    1 create view other as select a.name, a.age from user as a;

    这样的话,使用sql语句:select * from other; 最多就只能获取name和age的数据,其他的数据就获取不了了。

    作用四:

    让数据更加清晰。想要什么样的数据,就创建什么样的视图。经过以上三条作用的解析,这条作用应该很容易理解了吧

    展开全文
  • 视图,虚拟表,从一个表或多个表中导出来表,作用和真实表一样,包含一系列带有行和列数据 视图中,用户可以使用SELECT语句查询数据,也可以使用INSERT,UPDATE,DELETE修改记录,视图可以使用户操作方便,并...

    视图,虚拟表,从一个表或多个表中导出来的表,作用和真实表一样,包含一系列带有行和列的数据 视图中,用户可以使用SELECT语句查询数据,也可以使用INSERT,UPDATE,DELETE修改记录,视图可以使用户操作方便,并保障数据库系统安全

    c1d10564ee752d63492612f22b897bb7.png

    优点及缺点

    优点

    简单化,数据所见即所得

    安全性,用户只能查询或修改他们所能见到得到的数据

    逻辑独立性,可以屏蔽真实表结构变化带来的影响

    缺点

    性能相对较差,简单的查询也会变得稍显复杂

    修改不方便,特变是复杂的聚合视图基本无法修改

    创建视图语法详解

    语法结构:

    { CREATE|REPLACE } [ALGORITHM = {UNDEFINED | MERGE | TEMPTABLE}]

    VIEW view_name [{column_list}]

    AS SELECT_STATEMENT

    [WITH [CASCADED | LOCAL |] CHECK OPTION]

    释义:

    CREATE|REPLACE : 【创建|替换已创建的】视图

    ALGORITHM : 视图算法

    1.UNDEFINED 系统自动选择算法2.MERGE使用的视图语句与视图定义合并起来3.TEMPTABLE 结果存入临时表,然后用临时表执行语句view_name : 视图名称

    column_list : 属性列

    SELECT_STATEMENT :SELECT语句

    [WITH [CASCADED | LOCAL |] CHECK OPTION] 表示视图在更新时保证在视图的权限范围内

    1.CASCADED 默认值 更新视图时要满足所有相关视图和表的条件,2.LOCAL表示更新视图时满足该视图本身定义的条件即可。示例用表

    b318a7452a858517d0c3adaa9a68b164.png示例表t_user

    5f0449065a6bfbfa5915f7315829ecd2.png示例用表t_user_info

    创建视图示例

    # 1_1 在单表中创建视图

    CREATE VIEW test_view_1 AS SELECT `name` FROM t_user;

    d0e2ffcd62b87ac2e8cefc376ec9425d.png创建视图代码运行成功如图

    # 1_2 查询视图

    SELECT * FROM test_view_1;

    a455a79f35ad5978928e395a641e517f.png查询结果如图所示

    # 2_1 创建视图并指定视图字段名

    CREATE VIEW test_view_2(username) AS SELECT `name` FROM t_user;

    e91da2554248cf8f6bdfea3cba1cc0bd.png创建视图代码运行结果

    # 2_2 查询视图

    SELECT * FROM test_view_2;

    fccd14872e1f3fa6378ed046bc28ce9d.png如查询出来的字段名称为指定的usernam

    # 3_1 在多表中创建视图

    CREATE VIEW test_view_3 (username, userage, usersex) AS SELECT

    t_user.`name`,

    t_user_info.age,

    t_user_info.sex

    FROM

    t_user,

    t_user_info

    WHERE

    t_user.id = t_user_info.uid;

    1322961e1b9dea55c41967b49d08903c.png在多表中创建视图运行成功

    # 3_2 查询视图

    SELECT * FROM test_view_3;

    200885826d69c5476a8acfb171452b5a.png多表视图查询结果

    展开全文
  • 视图,虚拟表,从一个表或多个表中导出来表,作用和真实表一样,包含一系列带有行和列数据 视图中,用户可以使用SELECT语句查询数据,也可以使用INSERT,UPDATE,DELETE修改记录,视图可以使用户操作方便,并...

    视图,虚拟表,从一个表或多个表中导出来的表,作用和真实表一样,包含一系列带有行和列的数据 视图中,用户可以使用SELECT语句查询数据,也可以使用INSERT,UPDATE,DELETE修改记录,视图可以使用户操作方便,并保障数据库系统安全

    优点及缺点

    优点

    简单化,数据所见即所得

    安全性,用户只能查询或修改他们所能见到得到的数据

    逻辑独立性,可以屏蔽真实表结构变化带来的影响

    缺点

    性能相对较差,简单的查询也会变得稍显复杂

    修改不方便,特变是复杂的聚合视图基本无法修改

    创建视图语法详解

    语法结构:

    { CREATE|REPLACE } [ALGORITHM = {UNDEFINED | MERGE | TEMPTABLE}]

    VIEW view_name [{column_list}]

    AS SELECT_STATEMENT

    [WITH [CASCADED | LOCAL |] CHECK OPTION]

    释义:

    CREATE|REPLACE : 【创建|替换已创建的】视图

    ALGORITHM : 视图算法

    1.UNDEFINED 系统自动选择算法2.MERGE使用的视图语句与视图定义合并起来3.TEMPTABLE 结果存入临时表,然后用临时表执行语句view_name : 视图名称

    column_list : 属性列

    SELECT_STATEMENT :SELECT语句

    [WITH [CASCADED | LOCAL |] CHECK OPTION] 表示视图在更新时保证在视图的权限范围内

    1.CASCADED 默认值 更新视图时要满足所有相关视图和表的条件,2.LOCAL表示更新视图时满足该视图本身定义的条件即可。

    示例用表

    b318a7452a858517d0c3adaa9a68b164.png

    示例表t_user

    5f0449065a6bfbfa5915f7315829ecd2.png

    示例用表t_user_info

    创建视图示例

    # 1_1 在单表中创建视图

    CREATE VIEW test_view_1 AS SELECT `name` FROM t_user;

    d0e2ffcd62b87ac2e8cefc376ec9425d.png

    创建视图代码运行成功如图

    # 1_2 查询视图

    SELECT * FROM test_view_1;

    a455a79f35ad5978928e395a641e517f.png

    查询结果如图所示

    # 2_1 创建视图并指定视图字段名

    CREATE VIEW test_view_2(username) AS SELECT `name` FROM t_user;

    e91da2554248cf8f6bdfea3cba1cc0bd.png

    创建视图代码运行结果

    # 2_2 查询视图

    SELECT * FROM test_view_2;

    fccd14872e1f3fa6378ed046bc28ce9d.png

    如查询出来的字段名称为指定的usernam

    # 3_1 在多表中创建视图

    CREATE VIEW test_view_3 (username, userage, usersex) AS SELECT

    t_user.`name`,

    t_user_info.age,

    t_user_info.sex

    FROM

    t_user,

    t_user_info

    WHERE

    t_user.id = t_user_info.uid;

    1322961e1b9dea55c41967b49d08903c.png

    在多表中创建视图运行成功

    # 3_2 查询视图

    SELECT * FROM test_view_3;

    200885826d69c5476a8acfb171452b5a.png

    多表视图查询结果

    展开全文
  • 视图,虚拟表,从一个表或多个表中导出来表,作用和真实表一样,包含一系列带有行和列数据 视图中,用户可以使用SELECT语句查询数据,也可以使用INSERT,UPDATE,DELETE修改记录,视图可以使用户操作方便,并...
  • 视图,虚拟表,从一个表或多个表中导出来表,作用和真实表一样,包含一系列带有行和列数据 视图中,用户可以使用SELECT语句查询数据,也可以使用INSERT,UPDATE,DELETE修改记录,视图可以使用户操作方便,并...
  • 视图,虚拟表,从一个表或多个表中导出来表,作用和真实表一样,包含一系列带有行和列数据 视图中,用户可以使用SELECT语句查询数据,也可以使用INSERT,UPDATE,DELETE修改记录,视图可以使用户操作方便,并...
  • 数据库–视图的基本概念以及作用 转自:https://blog.csdn.net/buhuikanjian/article/details/53105416 视图(子查询):是从一个或多个表导出虚拟表,其内容由查询定义。具有普通表结构,但是不实现数据存储...
  • 视图(子查询):是从一个或多个表导出虚拟表,其内容由查询定义。具有普通表结构,但是不实现数据存储。 对视图的修改: 单表视图一般用于查询和修改,会改变基本表数据, 多表视图一般用于查询,不会...
  • 一、什么是视图视图作用 视图是一个虚拟图,视图并没有数据结构,只是一个虚拟的存在。我们在操作一个数据库表时,有些字段的值我们不想让别人看到,比如工资...从上图可以看出,as后的select语句查询的内容不...
  • SQL语言之视图前言本章我们将学习MySQL中的视图,视图是数据库中的重要组件,本文将从视图是什么,视图的作用,创建和使用视图以及修改视图这些方面讲解视图。视图是什么视图View是一种虚拟的表,本身不保存数据,内部封装...
  • 视图(子查询):是从一个或多个表导出虚拟表,其内容由查询定义。具有普通表结构,但是不实现数据存储。 对视图的修改:单表视图一般用于查询和修改,会改变基本表数据, 多表视图一般用于查询,不会改变...
  • 序列 创建:create sequence 序列名 特点: ...作用:动态生成一系列数字,常用于为某张表主键字段提供值使用,这样新增数据极大避免了主键冲突问题 使用序列名.nextval作为主键 删除:dro...
  • Hive视图和索引以及MySQL,Hive,Hbase视图概念相关理解一、HiveQL视图和索引(1)、视图:Hive中的视图作用总的来说就是为了简化查询语句,是一个逻辑上的视图,而不是物化的视图。索引则是加快查询速度的比较...
  • 安全:使用视图的用户只能访问他们被允许查询的结果集,对表的权限管理并不能限制到某个行某个列,但是通过视图就可以简单的实现。 数据独立:一旦视图的结构确定了,可以屏蔽表结构变化对用户的
  • 前言本章我们将学习MySQL中的视图,视图是数据库中的重要组件,本文将从视图是什么,视图的作用创建和使用视图以及修改视图这些方面讲解视图。视图是什么视图View是一种虚拟的表,本身不保存数据,内部封装了一条...
  • SQL语言之视图前言本章我们将学习MySQL中的视图,视图是数据库中的重要组件,本文将从视图是什么,视图的作用,创建和使用视图以及修改视图这些方面讲解视图。视图是什么视图View是一种虚拟的表,本身不保存数据,内部封装...
  • 一:视图 1:定义:视图本质上是一张虚拟表,它数据来自select语句。 2:创建视图的语句: create view 视图名字as select *from 表名;...因为视图可以将查询结果保存,所以可以用视图来减少书写sql...
  • SQL语言之视图前言本章我们将学习MySQL中的视图,视图是数据库中的重要组件,本文将从视图是什么,视图的作用,创建和使用视图以及修改视图这些方面讲解视图。视图是什么视图View是一种虚拟的表,本身不保存数据,内部封装...
  • MySQL之视图

    2019-06-20 08:20:24
    SQL语言之视图前言本章我们将学习MySQL中的视图,视图是数据库中的重要组件,本文将从视图是什么,视图的作用,创建和使用视图以及修改视图这些方面讲解视图。视图是什么视图View是一种虚拟的表,本身不保存数据,内部封装...
  • MySQL数据库—视图、约束与索引 ###视图view **- 什么是视图:**数据库中表和视图都是其内部的对象,视图本质其实是取代了一段SQL查询语句,视图没有自己独立的数据...创建一个10号部门的视图 create view v_emp_10...
  • 视图本质上就是一条SELECT语句,所以当访问视图时,只能访问到所对应SELECT语句中涉及到列,对基表中其它列起到安全和保密的作用,可以限制数据访问。 节省存储设备容量。因为使用视图时并不会将数据保存到...

空空如也

空空如也

1 2 3 4 5 ... 8
收藏数 150
精华内容 60
关键字:

创建查询的视图以及作用