zoukankan      html  css  js  c++  java
  • 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存储引擎

  • 相关阅读:
    Trie
    [转]Tarjan应用:求割点/桥/缩点/强连通分量/双连通分量/LCA(最近公共祖先)
    [Bzoj2242]常见数值算法
    JavaScript百炼成仙(记录笔记)
    tcpreplay重放报文,tcpdump能抓到包,应用程序收不到包
    用jquery tools来实现选项卡
    ExtNet第二篇
    线性表最简单的表示
    c语言中线性表基本操作方法
    ExtNet第一篇
  • 原文地址:https://www.cnblogs.com/isuben/p/7872304.html
Copyright © 2011-2022 走看看