美文网首页
MySql创建视图

MySql创建视图

作者: HandsomeBo_4c50 | 来源:发表于2022-06-30 17:04 被阅读0次

(1).第一类:create view v as select * from table;

(2).第二类:create view v as select id,name,age from table;

(3).第三类:create view v[vid,vname,vage] as select id,name,age from table;

如果涉及到数据量过大,业务逻辑需要跨表查询等等也可建立一个跨表的视图,有三种情况:

一、基于同一数据库

这种情况较为简单,只需简单的一行sql命令,如下:

create view v as (select * from table1) union all (select * from table2);

二、基于不同数据库

这种情况只比上面的sql语句多一个数据库的名字,如下:

create view 数据库1.v as (select * from 数据库1.table1) union all (select * from 数据库2.table2);

create view 数据库2.v as (select * from 数据库1.table1) union all (select * from 数据库2.table2);

如果执行第一个sql将在数据库1下建立视图,反之亦然;

三、基于不同服务器

这种情况稍微麻烦一点,需要先建立一个远程表来访问远程服务器的数据表,然后再对这个刚建立的远程表和本地表进行视图,步骤如下:

1、查看MySql是否支持federated引擎

    (1).登录Mysql;   

    (2).mysql>show engines;

    (3).如果显示为no,在配置文件中添加:federated (在my.ini),重新启动mysql服务。

2、创建远程表

    mysql>CREATE TABLE federated_table (

                  id  INT(20)  NOT NULL AUTO_INCREMENT, 

                  name  VARCHAR(32) NOT NULL DEFAULT '', 

                  other  INT(20) NOT NULL DEFAULT '0', 

                  PRIMARY KEY  (id)

                )

                ENGINE=FEDERATEDDEFAULT

                CHARSET=utf8

                CONNECTION='mysql://fed_user@remote_host:9306/federated/test_table';

CONNECTION可以按如下方式进行配置:

      (1).CONNECTION='mysql://username:password@hostname:port/database/tablename'

      (2).CONNECTION='mysql://username@hostname/database/tablename'

      (3).CONNECTION='mysql://username:password@hostname/database/tablename'

3、建立视图

create view 本地数据库.v as (select * from 本地数据库.table1) union all (select * from 远程数据库.test_table);


附 : 

1、删除视图  DROP VIEW IF EXISTS 视图名;

2、对于创建视图中的 SELECT 语句的指定存在以下限制:

用户除了拥有 CREATE VIEW 权限外,还具有操作中涉及的基础表和其他视图的相关权限。

SELECT 语句不能引用系统或用户变量。

SELECT 语句不能包含 FROM 子句中的子查询。

SELECT 语句不能引用预处理语句参数。

3、视图定义中引用的表或视图必须存在。但是,创建完视图后,可以删除定义引用的表或视图。可使用 CHECK TABLE 语句检查视图定义是否存在这类问题。

视图定义中允许使用 ORDER BY 语句,但是若从特定视图进行选择,而该视图使用了自己的 ORDER BY 语句,则视图定义中的 ORDER BY 将被忽略。

视图定义中不能引用 TEMPORARY 表(临时表),不能创建 TEMPORARY 视图。

WITH CHECK OPTION 的意思是,修改视图时,检查插入的数据是否符合 WHERE 设置的条件。

原文链接:https://blog.csdn.net/qq_38570633/article/details/119870383


相关文章

  • MySQL--索引

    MySQL索引 查看索引 创建索引 创建唯一索引 创建主键索引 删除索引 删除主键 MySQL视图 创建视图 删除...

  • MySql创建视图

    (1).第一类:create view v as select * from table; (2).第二类:cre...

  • MySQL 指南(二)

    本篇文章继续沿用 MySQL 指南(一) 中创建的 student 和 address 表。 视图为什么创建视图?...

  • MySQL的视图

    MySQL的视图 创建基础表 视图的测试 视图的分类 单源表视图:视图的数据可以只取自一个基本表的部分行、列,这样...

  • MySQL相关

    基础 MySQL-视图 什么是视图 通俗的讲,视图就是一条SELECT语句执行后返回的结果集。所以我们在创建视图的...

  • 视图

    视图1,虚拟表,mysql5.1版本出现的特性,是通过表动态的生成的数据。创建视图CREATE VIEW <视图名...

  • MySQL DEFINER详解

    前言: 在 MySQL 数据库中,在创建视图及函数的时候,你有注意过 definer 选项吗?在迁移视图或函数后是...

  • 推荐收藏 —— MySQL视图详细介绍

    前言: 在MySQL中,视图可能是我们最常用的数据库对象之一了。那么你知道视图和表的区别吗?你知道创建及使用视图要...

  • 视图

    视图虚拟表,和普通表一样使用Mysql5.1的新特性,通过普通表动态生成的数据 一、创建视图create view...

  • MySQL 创建表的分层视图

    备注:测试数据库版本为MySQL 8.0 如需要scott用户下建表及录入数据语句,可参考:scott建表及录入数...

网友评论

      本文标题:MySql创建视图

      本文链接:https://www.haomeiwen.com/subject/woofbrtx.html