標籤:
視圖:
視圖本身是一個虛擬表,不存放任何資料。
在使用sql語句訪問視圖的時候,它返回的資料是Mysql從其他表產生的。
視圖和表在同一個命名空間,MySQL在很多地方低於視圖和表是同樣對待的。
不過視圖和表也有不同,例如,不能對視圖建立觸發器,也不呢過使用drop table 命令刪除視圖
實現演算法有兩種:
merge: 合并演算法,儘可能使用這個
Temptable:暫存資料表演算法。如果視圖中高寒GROUP BU, DISTINCT, 任何彙總函式, UNION, 子查詢等
只要無法在原表記錄和視圖記錄建立一一映射的情境中,mysql都將用暫存資料表演算法實現視圖。
explain select * from <view_name>
id select_type
1 primary
2 derived
說明該表是由暫存資料表演算法實現的。
可更新視圖:
指可以通過更新這個視圖來更新視圖涉及的相關表。
如果視圖定義中包含了group by,union 彙總函式,以及其他一些特殊情況,就不能更新。
更新視圖的查詢也可以是一個關語句,但是有一個限制,被更新的列必須來自同一個表中。
另外,所有使用暫存資料表演算法實現的視圖都無法被更新。
可以使用視圖實現基於列的許可權控制,卻不需要真正的在系統中建立列許可權,因為沒有額外的開銷。
使用暫存資料表演算法實現的視圖,在某些時候效能會很糟糕。
mysql以遞迴的方式執行這類別檢視,先會執行外層查詢,即使外層查詢最佳化工具將其最佳化得很好,但是mysql
最佳化可能無法像其他的資料庫那樣做更多的內外結合的最佳化。
外層查詢的where條件無法下推到構建視圖的暫存資料表的查詢中,暫存資料表也無法建立索引。
mysql視圖的限制:
mysql不支援物化視圖(物化視圖是指將視圖結果資料存放在一個可以查看的表中,並定期從原始表中重新整理資料到這個表)
mysql視圖不會儲存視圖定義的原始sql語句。show create view 會以一種不友好的內部格式呈現。
MySQL之進階特性---視圖