本文实例讲述了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语句,并不保存实际数据
  • 临时表是保存在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

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

内存表的建立:

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

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

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

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

更多相关文章

  1. 《Android和PHP最佳实践》官方站
  2. 如何去掉状态栏和内容视图之间的黑色阴影线
  3. android用户界面之按钮(Button)教程实例汇
  4. android中文api(89)——ViewManager
  5. Android中的FILL_PARENT与WRAP_CONTENT的区别
  6. TabHost与RadioGroup结合完成的菜单【带效果图】5个Activity
  7. android用户界面-组件Widget-地图视图MapView
  8. Android(安卓)中文API(86)——ResourceCursorAdapter
  9. android用户界面-组件Widget-画廊视图Gallery

随机推荐

  1. Android中的消息机制:Handler消息传递机制
  2. Android(安卓)Studio系列教程六--Gradle
  3. android Animation 动画效果介绍 续 .
  4. Android中的多媒体编程-黄俊东-专题视频
  5. android EditText inputType 及 android:
  6. 【转载】Andoid Studio-android开发02-第
  7. 如何跟踪调试Android的源码
  8. Android开发 - 获取Android设备的唯一标
  9. 【Android布局】在程序中设置android:gra
  10. android颜色渐变的顶部标题栏