[視圖](http://www.hmoore.net/aakng/mysql/211264)
視圖就是一張虛表,只存儲表結構,并不存儲表真實數據,數據是在查詢時動態生成的。
使用視圖的好處:
更方便,簡化了操作,我們只需要使用視圖獲取數據,無需知道怎么處理的;
更安全,我們只能訪問到視圖就能得到數據,無需訪問原表;
降低耦合性,表結構更改時,只需要調整下視圖,無需更改應用程序代碼。
1、創建視圖
create view v1 as select * from aa;
create view v1(id,name) as select id,name from aa;
create or replace view v1 as select 語句; #視圖已存在時創建
完整語法:create [algorithm = undefined/merge/temptable] view 視圖名 as 查詢語句 [with [cascaded/local] check option];
通過 algorithm 可以選取相應的算法來從基表展示數據:
(1) merge:把從視圖取數據的 SQL 改變成從原表取數據的 SQL;
(2) temptable:將視圖的結果放置到臨時表中,然后使用它執行語句,此時視圖不可更新;
(3) undefined:MySQL 自動選擇。
2、查看視圖
show tables;
desc v1;
show create view v1\G;
show status like [from db_name] [like tbl_name];
select * from v1;
3、更新視圖
update v1 set name = 'shang' where id = 1;
以下類型的視圖是不能更新的:
(1) 包含聚合函數、distinct、group by、having、union、union all;
(2) 常量視圖;
(3) select 包含子查詢;
(4) 包含連接操作;
(5) from 一個不能更新的視圖;
(6) where 子句的子查詢引用了 from 子句中的表。
4、插入視圖
insert into v1 select value1,value2;
關鍵字 with check option 在插入時進行檢查,滿足視圖條件才允許操作,否則拒絕,比如:
create view v2(name,age) as select name,age from info where age < 20 with check option;
insert into v2 select 'shang',24; #拒絕操作,因為不滿足視圖條件(age < 20)
其他參數:with [local/cascaded] check option
local:只需滿足本視圖條件;
cascaded:默認值,需滿足所有視圖條件(即在視圖派生視圖時,滿足每個視圖條件);
5、修改視圖
alter view v1 ...;
6、刪除視圖
drop [if exists] view v1,v2,...;
總結:
(1) 視圖更多的是提供了一個中間層的功能,來屏蔽一些我們的操作。
(2) MySQL 的視圖功能還是比較弱的,比如說不支持物化視圖等等。
- 數據庫
- CAP定理
- 關系模型
- 關系數據庫
- NoSQL
- ODBC
- JDBC
- ODBC、JDBC和四種驅動類型
- mysql
- 安裝與配置
- CentOS 7 安裝 MySQL
- 優化
- 比較全面的MySQL優化參考
- 1、硬件層相關優化
- 1.1、CPU相關
- 1.2、磁盤I/O相關
- 2、系統層相關優化
- 2.1、文件系統層優化
- 2.2、其他內核參數優化
- 3、MySQL層相關優化
- 3.1、關于版本選擇
- 3.2、關于最重要的參數選項調整建議
- 3.3、關于Schema設計規范及SQL使用建議
- 3.4、其他建議
- 后記
- Mysql設計與優化專題
- ER圖,數據建模與數據字典
- 數據中設計中的范式與反范式
- 字段類型與合理的選擇字段類型
- 表的垂直拆分和水平拆分
- 詳解慢查詢
- mysql的最佳索引攻略
- 高手詳解SQL性能優化十條經驗
- 優化SQL查詢:如何寫出高性能SQL語句
- MySQL索引原理及慢查詢優化
- 數據庫SQL優化大總結之 百萬級數據庫優化方案
- 數據庫性能優化之SQL語句優化1
- 【重磅干貨】看了此文,Oracle SQL優化文章不必再看!
- MySQL 對于千萬級的大表要怎么優化?
- MySQL 數據庫設計總結
- MYSQL性能優化的最佳20+條經驗
- 數據操作
- 數據語句操作類型
- DCL
- 修改Mysql數據庫名的5種方法
- DML
- 連接
- 連接2
- DDL
- 數據類型
- 字符集
- 表引擎
- 索引
- MySQL理解索引、添加索引的原則
- mysql建索引的幾大原則
- 淺談mysql的索引設計原則以及常見索引的區別
- 常用工具簡介
- QA
- MySQL主機127.0.0.1與localhost區別總結
- 視圖(view)
- 觸發器
- 自定義函數和存儲過程的使用
- 事務(transaction)
- 范式與反范式
- 常用函數
- MySQL 數據類型 詳解
- Mysql數據庫常用分庫和分表方式
- 隔離級別
- 五分鐘搞清楚MySQL事務隔離級別
- mysql隔離級別及事務傳播
- 事務隔離級別和臟讀的快速入門
- 數據庫引擎中的隔離級別
- 事務隔離級別
- Innodb中的事務隔離級別和鎖的關系
- MySQL 四種事務隔離級的說明
- Innodb鎖機制:Next-Key Lock 淺談
- SQL函數和存儲過程的區別
- mongo
- MongoDB設置訪問權限、設置用戶
- redis
- ORM
- mybatis
- $ vs #
- mybatis深入理解(一)之 # 與 $ 區別以及 sql 預編譯
- 電商設計
- B2C電子商務系統研發——概述篇
- B2C電子商務系統研發——商品數據模型設計
- B2C電子商務系統研發——商品模塊E-R圖建模
- B2C電子商務系統研發——商品SKU分析和設計(一)
- B2C電子商務系統研發——商品SKU分析和設計(二)
- 數據庫命名規范--通用