各位用户为了找寻关于mysql视图功能与用法实例分析的资料费劲了很多周折。这里教程网为您整理了关于mysql视图功能与用法实例分析的相关资料,仅供查阅,以下为您介绍关于mysql视图功能与用法实例分析的详细内容
本文实例讲述了mysql视图功能与用法。分享给大家供大家参考,具体如下:
通俗的讲,视图就是一条SELECT语句执行后返回的结果集。
? 1 2 3 4 5 6 7 8 9 10//单表视图
CREATE
[ALGORITHM]={UNDEFINED|MERGE|TEMPTABLE}]
VIEW
视图名 [(属性清单)]
AS
SELECT
语句
[
WITH
[CASCADED|
LOCAL
]
CHECK
OPTION
];
//将查询到的结果返回为一个虚拟表,会根据数据库变化而变化
CREATE
VIEW
work_view(ID,
Name
, Addr)
AS
SELECT
id,
name
,address
FROM
work
;
//多表上创建视图
//ALGORITHM=MERGE ALGORITHM有三个参数分别是:merge、TEMPTABLE、UNDEFINED(merge合并表,temptable无法更新信息,undefined)
CREATE
ALGORITHM=MERGE
VIEW
work_view2(ID,
NAME
,SALARY)
AS
SELECT
work
.id,
name
,salary
FROM
work
,salary
WHERE
work
.id=salary.id
WITH
LOCAL
CHECK
OPTION
;
方便操作,特别是查询操作,减少复杂的SQL语句,增强可读性;
视图与表是一对一关系情况:如果没有其它约束(如视图中没有的字段,在基本表中是必填字段情况),是可以进行增删改数据操作;
视图与表是一对多关系情况:如果只修改一张表的数据,且没有其它约束(如视图中没有的字段,在基本表中是必填字段情况),是可以进行改数据操作,如以下语句,操作成功;
视图和临时表的区别
视图只是一条预编译的SQL语句,并不保存实际数据 临时表是保存在tempdb中的实际的表 物理空间的分配不一样,试图不分配空间, 临时表会分配空间 视图是一个快照,是一个虚表 临时表是客观存在的表类型对象Create TEMPORARY table 它们的结构一个是表、一个快照。可以把视图像象成联合表的快捷方式创建临时表
? 1 2 3CREATE
TEMPORARY
TABLE
tmp_table (
name
VARCHAR
(10)
NOT
NULL
,
value
INTEGER
NOT
NULL
)
直接将查询结果导入临时表
? 1CREATE
TEMPORARY
TABLE
tmp_table
SELECT
*
FROM
table_name
临时表只在当前连接可见,当这个连接关闭的时候,会自动drop。在同一个query语句中,你只能查找一次临时表。show tables 语句不会列举临时表,但是会列出内存表。你不能用rename来重命名一个临时表。但是,你可以alter table代替:
内存表:表结构建在磁盘里,数据在内存里 ,当停止服务后,表中的数据丢失,而表的结构不会丢失。内存表也可以被看作是临时表的一种。
内存表的建立:
? 1 2 3 4CREATE
TEMPORARY
TABLE
tmp_table (
name
VARCHAR
(10)
NOT
NULL
,
value
INTEGER
NOT
NULL
) TYPE = HEAP
注意: TYPE = HEAP必须要有。
内存表必须使用memory存储引擎
希望本文所述对大家MySQL数据库计有所帮助。
原文链接:https://www.cnblogs.com/isuben/p/7872304.html