当前位置: 首页 > 编程笔记 >

mysql视图功能与用法实例分析

充星腾
2023-03-14
本文向大家介绍mysql视图功能与用法实例分析,包括了mysql视图功能与用法实例分析的使用技巧和注意事项,需要的朋友参考一下

本文实例讲述了mysql视图功能与用法。分享给大家供大家参考,具体如下:

通俗的讲,视图就是一条SELECT语句执行后返回的结果集。

//单表视图
  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
  • 它们的结构一个是表、一个快照。可以把视图像象成联合表的快捷方式

创建临时表

CREATE TEMPORARY TABLE tmp_table (
name VARCHAR(10) NOT NULL,
value INTEGER NOT NULL)

直接将查询结果导入临时表

CREATE TEMPORARY TABLE tmp_table SELECT * FROM table_name

临时表只在当前连接可见,当这个连接关闭的时候,会自动drop。在同一个query语句中,你只能查找一次临时表。show tables 语句不会列举临时表,但是会列出内存表。你不能用rename来重命名一个临时表。但是,你可以alter table代替:

内存表:表结构建在磁盘里,数据在内存里 ,当停止服务后,表中的数据丢失,而表的结构不会丢失。内存表也可以被看作是临时表的一种。

内存表的建立:

CREATE TEMPORARY TABLE tmp_table (
name VARCHAR(10) NOT NULL,
value INTEGER NOT NULL
) TYPE = HEAP

注意: TYPE = HEAP必须要有。

内存表必须使用memory存储引擎

更多关于MySQL相关内容感兴趣的读者可查看本站专题:《MySQL查询技巧大全》、《MySQL事务操作技巧汇总》、《MySQL存储过程技巧大全》、《MySQL数据库锁相关技巧汇总》及《MySQL常用函数大汇总》

希望本文所述对大家MySQL数据库计有所帮助。

 类似资料:
  • 本文向大家介绍MySQL联合索引功能与用法实例分析,包括了MySQL联合索引功能与用法实例分析的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了MySQL联合索引功能与用法。分享给大家供大家参考,具体如下: 联合索引又叫复合索引。对于复合索引:Mysql从左到右的使用索引中的字段,一个查询可以只使用索引中的一部份,但只能是最左侧部分。例如索引是key index (a,b,c). 可以支持a

  • 本文向大家介绍javascript闭包功能与用法实例分析,包括了javascript闭包功能与用法实例分析的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了javascript闭包功能与用法。分享给大家供大家参考,具体如下: 理解闭包 闭包这个东西,确实是很麻烦。之前我自己的理解也是有一点误差,所以今天将文章修改修改,争取将自己的理解进一步准确化。 闭包说得通熟易懂一点,就是指有权访问另一个

  • 本文向大家介绍mysql视图原理与用法实例小结,包括了mysql视图原理与用法实例小结的使用技巧和注意事项,需要的朋友参考一下 本文实例总结了mysql视图原理与用法。分享给大家供大家参考,具体如下: 一、什么是视图 视图是指计算机数据库中的视图,是一个虚拟表,其内容由查询定义。同真实的表一样,视图包含一系列带有名称的列和行数据。但是,视图并不在数据库中以存储的数据值集形式存在。行和列数据来自由定

  • 本文向大家介绍JQuery常用选择器功能与用法实例分析,包括了JQuery常用选择器功能与用法实例分析的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了JQuery常用选择器功能与用法。分享给大家供大家参考,具体如下: JQuery基础回顾 今天对JQuery内容进行了回顾,下面进行一些总结: JQuery是javascript的一个库,所以二者可以相互转换,例如JQuery到Javascr

  • 本文向大家介绍JavaScript内置对象math,global功能与用法实例分析,包括了JavaScript内置对象math,global功能与用法实例分析的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了JavaScript内置对象math,global功能与用法。分享给大家供大家参考,具体如下: 学习要点: 1.Global对象 2.Math对象 ECMA-262对内置对象的定义是:“

  • 本文向大家介绍Yii视图CGridView列表用法实例分析,包括了Yii视图CGridView列表用法实例分析的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Yii视图CGridView列表用法。分享给大家供大家参考,具体如下: CGridView列表实例 修改基类,定义底部功能菜单framework/zii/widgets/grid/CGridView.php(152) 修改视图,实现底