欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2023-12-01 08:21:52
本文实例讲述了mysql视图功能与用法。分享给大家供大家参考,具体如下: 通俗的讲,视图就是一条select语句执行后返回的结果集。 //单表视图 cre...

本文实例讲述了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数据库计有所帮助。