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

巧解如何編寫可重用的MySQL查詢(1)

編輯: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 wa on uwh.affiliation_id = wa.affiliation_id

下面,我們用一個視圖來替換上面的查找過程:

CREATE VIEW `vusers` AS
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 wa on uwh.affiliation_id = wa.affiliation_id;

現在,我們可以通過以下簡單的選擇語句來檢索用戶概要信息了:

select *
from vusers u

where u.user_id = 100


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