MySQL之進階特性---視圖

來源:互聯網
上載者:User

標籤:

視圖:
  視圖本身是一個虛擬表,不存放任何資料。
  在使用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之進階特性---視圖

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.