当前位置:Gxlcms > 数据库问题 > MySQL数据库之视图

MySQL数据库之视图

时间:2021-07-01 10:21:17 帮助过:7人阅读

NAMES utf8mb4; SET FOREIGN_KEY_CHECKS = 0; -- ---------------------------- -- Table structure for emp -- ---------------------------- DROP TABLE IF EXISTS `emp`; CREATE TABLE `emp` ( `empno` int(4) NOT NULL, `ename` varchar(10) CHARACTER SET latin1 COLLATE latin1_swedish_ci NULL DEFAULT NULL, `job` varchar(9) CHARACTER SET latin1 COLLATE latin1_swedish_ci NULL DEFAULT NULL, `mgr` int(4) NULL DEFAULT NULL, `hiredate` date NULL DEFAULT NULL, `sal` float(7, 2) NULL DEFAULT NULL, `comm` float(7, 2) NULL DEFAULT NULL, `deptno` int(2) NULL DEFAULT NULL, PRIMARY KEY (`empno`) USING BTREE ) ENGINE = InnoDB CHARACTER SET = latin1 COLLATE = latin1_swedish_ci ROW_FORMAT = Compact; -- ---------------------------- -- Records of emp -- ---------------------------- INSERT INTO `emp` VALUES (7369, SMITH, CLERK, 7902, 1998-12-17, 800.00, NULL, 20); INSERT INTO `emp` VALUES (7499, ALLEN, SALESMAN, 7698, 1981-02-20, 1600.00, 300.00, 30); INSERT INTO `emp` VALUES (7521, WARD, SALESMAN, 7698, 1981-02-22, 1250.00, 500.00, 30); INSERT INTO `emp` VALUES (7566, JONES, MANAGER, 7839, 1981-04-02, 2975.00, NULL, 20); INSERT INTO `emp` VALUES (7654, MARTIN, SALESMAN, 7698, 1981-09-28, 1250.00, 1400.00, 30); INSERT INTO `emp` VALUES (7698, BLAKE, MANAGER, 7839, 1981-05-01, 2850.00, NULL, 30); INSERT INTO `emp` VALUES (7782, CLARK, MANAGER, 7839, 1981-06-09, 2450.00, NULL, 10); INSERT INTO `emp` VALUES (7788, SCOTT, ANALYST, 7566, 1981-11-17, 3000.00, NULL, 20); INSERT INTO `emp` VALUES (7839, KING, PRESIDENT, NULL, 1981-11-17, 5000.00, NULL, 10); INSERT INTO `emp` VALUES (7844, TURNER, SALESMAN, 7698, 1981-09-08, 1500.00, 0.00, 30); INSERT INTO `emp` VALUES (7876, ADAMS, CLERK, 7788, 1987-05-23, 1100.00, NULL, 20); INSERT INTO `emp` VALUES (7900, JAMES, CLERK, 7698, 1981-12-03, 950.00, NULL, 30); INSERT INTO `emp` VALUES (7902, FORD, ANALYST, 7566, 1981-12-03, 3000.00, NULL, 20); INSERT INTO `emp` VALUES (7934, MILLER, CLERK, 7782, 1982-02-23, 1300.00, NULL, 10); INSERT INTO `emp` VALUES (8888, CHB, CLERK, 7369, 2018-12-10, 8000.00, 100.00, NULL); SET FOREIGN_KEY_CHECKS = 1; emp表SQL语句

  dept表:

   技术分享图片

  dept表SQL语句如下:

技术分享图片
SET NAMES utf8mb4;

SET FOREIGN_KEY_CHECKS = 0;

 

-- ----------------------------

-- Table structure for dept

-- ----------------------------

DROP TABLE IF EXISTS `dept`;

CREATE TABLE `dept`  (

  `deptno` int(2) NOT NULL,

  `dname` varchar(14) CHARACTER SET latin1 COLLATE latin1_swedish_ci NULL DEFAULT NULL,

  `loc` varchar(13) CHARACTER SET latin1 COLLATE latin1_swedish_ci NULL DEFAULT NULL,

  PRIMARY KEY (`deptno`) USING BTREE

) ENGINE = InnoDB CHARACTER SET = latin1 COLLATE = latin1_swedish_ci ROW_FORMAT = Compact;

 

-- ----------------------------

-- Records of dept

-- ----------------------------

INSERT INTO `dept` VALUES (10, ACCOUNTING, NEW YORK);

INSERT INTO `dept` VALUES (20, RESEARCH, DALLAS);

INSERT INTO `dept` VALUES (30, SALES, CHICAGO);

INSERT INTO `dept` VALUES (40, OPERATIONS, BOSTON);

 

SET FOREIGN_KEY_CHECKS = 1;
demp表SQL语句

3.1 创建视图的基本格式

         创建视图的基本格式如下:

   CREATE VIEW <视图名称> [(column_list)]

  AS SELECT语句;

  虽然还有更加完整的详细语法格式,但一般情况下,使用上述基本格式就够用了。

  (1)基于单个数据表建立视图

  在使用emp表时,如果需要查询查询empno(编号)、ename(姓名)、job(职位)、hiredate(雇用日期)、sal(月薪)等字段,并指定中文拼音别名,SQL语句如下:

select empno bianhao , ename xinmin, job zhiwei, hiredate guyongriqi, sal yuexin from emp;

         如果需要频繁得进行该语句查询,那么每次都要重写这一行语句。使用视图可以简化操作,对empno、ename、job、hiredate、sal创建视图:

create view view_01 as select empno , ename , job , hiredate , sal from emp;

  执行完上述语句即可创建名为view_01的视图,如果你是通过Navicat等图形界面工具创建视图,在左侧视图栏下可找到view_01视图。

   技术分享图片

  在刚创建好的view_01视图进行查询:

select * from view_01 ;

  查询结果如下:

   技术分享图片

  可以发现,我们并未指定查询的字段,但查询效果却与直接在真实数据表上指定字段查询效果一样。但view_01视图并未实现字段别名,继续创建一个view_02为每个列添加别名:

create view view_02 (bianhao , xinmin , zhiwei , guyongriqi , yuexin) as select empno , ename , job , hiredate , sal from emp;

  查看view_02:

select * from view_02 ;

  结果如下:

 技术分享图片

  可以看到,每一个列的列名都是我们在创建视图时自己重新指定的。

  (2)创建基于多个表上视图

         创建一个视图,视图中包含每个员工编号(empno)、姓名(ename)、职位(job)、领导编号(mgr)、领导姓名(empno)、部门名称(dname)、部门位置(loc),在真实数据表中查询语句如下:

select e1.empno bianhao, e1.ename xingming, e1.job zhiwei, e1.mgr lindaobianhao, e2.ename lindaoxingming, d.dname bumenmingchen, d.loc bumenweizhi

from emp e1 , emp e2 , dept d

where e1.mgr=e2.empno and e1.deptno=d.deptno ;

  创建视图:

create view view_03 as select e1.empno bianhao, e1.ename xingming, e1.job zhiwei, e1.mgr lindaobianhao, e2.ename lindaoxingming, 
d.dname bumenmingchen, d.loc bumenweizhi
from emp e1 , emp e2 , dept d where e1.mgr=e2.empno and e1.deptno=d.deptno ;

  对刚建立的view_03视图进行查询:

select * from view_03 ;

  查询结果如下:

 技术分享图片

  可以发现,在select中指定别名与在view视图中指定别名效果是一样的。

4 查看视图

  (1)查看视图基本信息:describe 视图名;

         查看上一章节创建的视图view_03的基本信息:

describe view_03 ;

技术分享图片

 

  describe一般情况下都写成desc,两者是完全等效的。

       另外还可以通过“show create view 视图名;”来查看视图详细信息。

  (2)查看所有视图

  在MySQL中,information_schema数据库下的views表中存储了所有视图的定义,通过对views表的查询,可以查看数据库中说哟视图的详细信息,查询语句如下:

select * FROM information_schema.views ;

  部分查询结果如下所示:

 技术分享图片

5 修改视图

  (1)使用create or replace view语句修改视图

  create or replace view语句从字面上也可以理解:既可以创建视图,也可以修改视图(存在的话就修改,不存在就创建)。create or replace view语句的语法结构与创建视图的create语句语法结构是完全一样的。

  修改上文中创建的视图view_01,添加一个部门编号字段(deptno):

create or replace view view_02 (bianhao , xinmin , zhiwei , guyongriqi , yuexin , bumenbiaohao) as select empno , ename , job , hiredate , sal , 
deptno from emp;

  再次查询view_02,发现确实多了部门编号这一列:

select * from view_02 ;

技术分享图片

 

  (2)使用alter语句修改视图

  alter语句是MySQL提供的另一种修改视图的方法,其语法结果与create or replace语句也是基本一样的。

  继续修改视图view_02,添加一个奖金字段(comm):

alter view view_02 (bianhao , xinmin , zhiwei , guyongriqi , yuexin , bumenbiaohao , jiangjin) as select empno , ename , job , hiredate , sal ,
deptno , comm from emp;

         查看view_01视图:

 技术分享图片

  alter语句与create orreplace语句的区别是当视图不存在是,alter语句会报错。

6 更新视图

  更新视图是指通过视图来插入、更新、删除表中的数据,因为视图是一个虚拟表,其中是没有数据的。通过视图更新的时候都是转到真实表上进行的。对视图的更新操作也包括update、insert和delete。

         (1)update

         通过视图将员工编号为7369的员工月薪改为1000,在更新前,其数据为:

select * from view_02 where bianhao=7369;

技术分享图片

 

  用update语句进行更新

update view_02 set yuexin=1000 where bianhao=7369;

  再次通过视图查看数据,发现数据确实已更新:

   技术分享图片

         再看看真实表中数据有没有更新:

select * from emp where empno=7369;

技术分享图片

          可以看出,真实表中的数据也一起更新了,说明对视图的更新操作本质上是对真实表的更新。

(2)insert

  先创建一个视图view_04,该视图结果与emp表一样:

create view view_04 as select * from emp ;

  使用insert语句向view_04视图中插入一条数据:

insert into view_04 values(8002 , MARK , CLERK ,  7902 , 1998-12-12 , 1100 ,  20 ,500 ) ;

  查看真实emp表中是否添加这么一条数据:

select * from emp where empno =8002  ;

技术分享图片

 

  证明在视图进行insert操作是可以添加数据到真实表的。但一般来说,视图的表结构与视图的表结构可能不一样,若真实表中存在非空等约束,这通过视图的insert操作就回失败。所以,insert操作一般不会通过视图来进行。

    (3)delete

  通过视图删除刚创建的empno为8002的记录:

delete from view_04 where empno =8002  ;

  查看真实表中数据是否删除:

select * from emp where empno =8002  ;

技术分享图片

   返回的是一个空表,证明真实表中的这条记录也已经被删除了。

  最后总结一下视图的更新操作,当视图中包含如下内容时,视图的更新操作将不能被执行:

  (1)视图中不包含真实表中被定义为非空的列(视图中没有,但真实表中为非空约束)。

  (2)在定义视图的select语句后的字段列表中使用了数学表达式。

  (3)在定义视图的select语句后的字段列表中使用了聚合函数。

  (4)在定义视图的select语句中使用了distinct,union,top, group by,或having子句。

7 总结

         本文是对MySQL数据中视图的详细总结,包括了对视图概念、特性的介绍,然后通过实际示例展示了对视图的增删改查操作。

MySQL数据库之视图

标签:ima   desc   efault   not   子集   inf   mys   one   一个   

人气教程排行