程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> 如何編寫可重用的MySQL查詢

如何編寫可重用的MySQL查詢

編輯:MySQL綜合教程

  當人們提及可重用的查詢的時候,立即映入腦海的往往就是存儲過程了。雖然這些存儲過程是編寫可重用代碼不可分割的一部分,但要記住的是,它們只是很少的一部分而已,而非全部。此外,其它可重用代碼包括視圖、內置函數以及用戶定義的函數。在本文中,我們將向讀者詳細介紹如何組合這些元素,以令我們的選擇語句可以更好的適用於各種查詢。

  一、關於視圖

  視圖的用途很多,例如簡化復雜的模式及查詢,或者提供安全性等等。視圖提供安全性的一種途徑是對開發者隱藏審計字段。視圖還可通過減少列的數目來提高性能。這個想法是只引用索引字段,而索引字段的搜索速度是非常之快的。實際上,這種想法實現起來很費勁,因為你必須確保不會訪問隱藏列。然而,我們這裡主要是利用視圖模擬兩個或更多個表之間的連接,以降低查詢的復雜性。很多時候,要想將數據庫中用戶的概要信息整理成符合第三范式的形式,可能需要多達六次連接操作,例如:

\select * 
\from   Users u
\  inner join UserPhoneNumbers upn on u.user_id          = upn.user_id
\  inner join UserScreenNames  usn on u.user_id          = usn.user_id
\  inner join UserAffiliations ua  on u.user_id          = ua.user_id
\  inner join Affiliations     a   on a.affiliation_id   = ua.affiliation_id
\  inner join UserWorkHistory  uwh on u.user_id          = uwh.user_id
\  inner join Affiliations 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved