使用示例
10年積累的成都網(wǎng)站制作、網(wǎng)站建設(shè)經(jīng)驗(yàn),可以快速應(yīng)對(duì)客戶對(duì)網(wǎng)站的新想法和需求。提供各種問(wèn)題對(duì)應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識(shí)你,你也不認(rèn)識(shí)我。但先網(wǎng)站設(shè)計(jì)后付款的網(wǎng)站建設(shè)流程,更有興文免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。
使用示例
使用示例
檢查選項(xiàng)的使用
mysql是可以基于視圖創(chuàng)建視圖,它會(huì)檢查視圖所依賴的視圖的規(guī)則
如果再基于v2創(chuàng)建視圖v3,v3沒(méi)有定義檢查選項(xiàng),則此時(shí)向v3中插入數(shù)據(jù)時(shí),不會(huì)檢查是否滿足v3的條件,但是會(huì)檢查是否滿足v2和v1的條件
local選項(xiàng)相比于cascaded,不會(huì)自動(dòng)向上添加選項(xiàng)
如創(chuàng)建一個(gè)視圖,此時(shí)視圖中只包含一條數(shù)據(jù)
例如,現(xiàn)要查詢每個(gè)學(xué)生選修的課程(多對(duì)多,三張表),將SQL保存到視圖,以后再想查詢,直接select * from 視圖即可
CREATE [OR REPLACE] [ALGORITHM = {UNDEFINED | MERGE | TEMPTABLE}]\x0d\x0a VIEW view_name [(column_list)]\x0d\x0a AS select_statement\x0d\x0a [WITH [CASCADED | LOCAL] CHECK OPTION]\x0d\x0a\x0d\x0a該語(yǔ)句能創(chuàng)建新的視圖,如果給定了OR REPLACE子句,該語(yǔ)句還能替換已有的視圖。select_statement是一種SELECT語(yǔ)句,它給出了視圖的定義。該語(yǔ)句可從基表或其他視圖進(jìn)行選擇。\x0d\x0a該語(yǔ)句要求具有針對(duì)視圖的CREATE VIEW權(quán)限,以及針對(duì)由SELECT語(yǔ)句選擇的每一列上的某些權(quán)限。對(duì)于在SELECT語(yǔ)句中其他地方使用的列,必須具有SELECT權(quán)限。如果還有OR REPLACE子句,必須在視圖上具有DROP權(quán)限。\x0d\x0a視圖屬于數(shù)據(jù)庫(kù)。在默認(rèn)情況下,將在當(dāng)前數(shù)據(jù)庫(kù)創(chuàng)建新視圖。要想在給定數(shù)據(jù)庫(kù)中明確創(chuàng)建視圖,創(chuàng)建時(shí),應(yīng)將名稱指定為db_name.view_name。\x0d\x0amysql CREATE VIEW test.v AS SELECT * FROM t;\x0d\x0a\x0d\x0a表和視圖共享數(shù)據(jù)庫(kù)中相同的名稱空間,因此,數(shù)據(jù)庫(kù)不能包含具有相同名稱的表和視圖。\x0d\x0a視圖必須具有唯一的列名,不得有重復(fù),就像基表那樣。默認(rèn)情況下,由SELECT語(yǔ)句檢索的列名將用作視圖列名。要想為視圖列定義明確的名稱,可使用可選的column_list子句,列出由逗號(hào)隔開(kāi)的ID。column_list中的名稱數(shù)目必須等于SELECT語(yǔ)句檢索的列數(shù)。\x0d\x0aSELECT語(yǔ)句檢索的列可以是對(duì)表列的簡(jiǎn)單引用。也可以是使用函數(shù)、常量值、操作符等的表達(dá)式。\x0d\x0a對(duì)于SELECT語(yǔ)句中不合格的表或視圖,將根據(jù)默認(rèn)的數(shù)據(jù)庫(kù)進(jìn)行解釋。通過(guò)用恰當(dāng)?shù)臄?shù)據(jù)庫(kù)名稱限定表或視圖名,視圖能夠引用表或其他數(shù)據(jù)庫(kù)中的視圖。\x0d\x0a能夠使用多種SELECT語(yǔ)句創(chuàng)建視圖。視圖能夠引用基表或其他視圖。它能使用聯(lián)合、UNION和子查詢。SELECT甚至不需引用任何表。在下面的示例中,定義了從另一表選擇兩列的視圖,并給出了根據(jù)這些列計(jì)算的表達(dá)式:\x0d\x0amysql CREATE TABLE t (qty INT, price INT);\x0d\x0amysql INSERT INTO t VALUES(3, 50);\x0d\x0amysql CREATE VIEW v AS SELECT qty, price, qty*price AS value FROM t;\x0d\x0amysql SELECT * FROM v;\x0d\x0a+------+-------+-------+\x0d\x0a| qty | price | value |\x0d\x0a+------+-------+-------+\x0d\x0a| 3 | 50 | 150 |\x0d\x0a+------+-------+-------+\x0d\x0a\x0d\x0a視圖定義服從下述限制:\x0d\x0a· SELECT語(yǔ)句不能包含F(xiàn)ROM子句中的子查詢。\x0d\x0a· SELECT語(yǔ)句不能引用系統(tǒng)或用戶變量。\x0d\x0a· SELECT語(yǔ)句不能引用預(yù)處理語(yǔ)句參數(shù)。\x0d\x0a· 在存儲(chǔ)子程序內(nèi),定義不能引用子程序參數(shù)或局部變量。\x0d\x0a· 在定義中引用的表或視圖必須存在。但是,創(chuàng)建了視圖后,能夠舍棄定義引用的表或視圖。要想檢查視圖定義是否存在這類問(wèn)題,可使用CHECK TABLE語(yǔ)句。\x0d\x0a· 在定義中不能引用TEMPORARY表,不能創(chuàng)建TEMPORARY視圖。\x0d\x0a· 在視圖定義中命名的表必須已存在。\x0d\x0a· 不能將觸發(fā)程序與視圖關(guān)聯(lián)在一起。\x0d\x0a在視圖定義中允許使用ORDER BY,但是,如果從特定視圖進(jìn)行了選擇,而該視圖使用了具有自己ORDER BY的語(yǔ)句,它將被忽略。\x0d\x0a對(duì)于定義中的其他選項(xiàng)或子句,它們將被增加到引用視圖的語(yǔ)句的選項(xiàng)或子句中,但效果未定義。例如,如果在視圖定義中包含LIMIT子句,而且從特定視圖進(jìn)行了選擇,而該視圖使用了具有自己LIMIT子句的語(yǔ)句,那么對(duì)使用哪個(gè)LIMIT未作定義。相同的原理也適用于其他選項(xiàng),如跟在SELECT關(guān)鍵字后的ALL、DISTINCT或SQL_SMALL_RESULT,并適用于其他子句,如INTO、FOR UPDATE、LOCK IN SHARE MODE、以及PROCEDURE。\x0d\x0a如果創(chuàng)建了視圖,并通過(guò)更改系統(tǒng)變量更改了查詢處理環(huán)境,會(huì)影響從視圖獲得的結(jié)果:\x0d\x0amysql CREATE VIEW v AS SELECT CHARSET(CHAR(65)), COLLATION(CHAR(65));\x0d\x0aQuery OK, 0 rows affected (0.00 sec)\x0d\x0a \x0d\x0amysql SET NAMES 'latin1';\x0d\x0aQuery OK, 0 rows affected (0.00 sec)\x0d\x0a \x0d\x0amysql SELECT * FROM v;\x0d\x0a+-------------------+---------------------+\x0d\x0a| CHARSET(CHAR(65)) | COLLATION(CHAR(65)) |\x0d\x0a+-------------------+---------------------+\x0d\x0a| latin1 | latin1_swedish_ci |\x0d\x0a+-------------------+---------------------+\x0d\x0a1 row in set (0.00 sec)\x0d\x0a \x0d\x0amysql SET NAMES 'utf8';\x0d\x0aQuery OK, 0 rows affected (0.00 sec)\x0d\x0a \x0d\x0amysql SELECT * FROM v;\x0d\x0a+-------------------+---------------------+\x0d\x0a| CHARSET(CHAR(65)) | COLLATION(CHAR(65)) |\x0d\x0a+-------------------+---------------------+\x0d\x0a| utf8 | utf8_general_ci |\x0d\x0a+-------------------+---------------------+\x0d\x0a1 row in set (0.00 sec)\x0d\x0a\x0d\x0a可選的ALGORITHM子句是對(duì)標(biāo)準(zhǔn)SQL的MySQL擴(kuò)展。ALGORITHM可取三個(gè)值:MERGE、TEMPTABLE或UNDEFINED。如果沒(méi)有ALGORITHM子句,默認(rèn)算法是UNDEFINED(未定義的)。算法會(huì)影響MySQL處理視圖的方式。\x0d\x0a對(duì)于MERGE,會(huì)將引用視圖的語(yǔ)句的文本與視圖定義合并起來(lái),使得視圖定義的某一部分取代語(yǔ)句的對(duì)應(yīng)部分。\x0d\x0a對(duì)于TEMPTABLE,視圖的結(jié)果將被置于臨時(shí)表中,然后使用它執(zhí)行語(yǔ)句。\x0d\x0a對(duì)于UNDEFINED,MySQL將選擇所要使用的算法。如果可能,它傾向于MERGE而不是TEMPTABLE,這是因?yàn)镸ERGE通常更有效,而且如果使用了臨時(shí)表,視圖是不可更新的。\x0d\x0a明確選擇TEMPTABLE的1個(gè)原因在于,創(chuàng)建臨時(shí)表之后、并在完成語(yǔ)句處理之前,能夠釋放基表上的鎖定。與MERGE算法相比,鎖定釋放的速度更快,這樣,使用視圖的其他客戶端不會(huì)被屏蔽過(guò)長(zhǎng)時(shí)間。\x0d\x0a視圖算法可以是UNDEFINED,有三種方式:\x0d\x0a· 在CREATE VIEW語(yǔ)句中沒(méi)有ALGORITHM子句。\x0d\x0a· CREATE VIEW語(yǔ)句有1個(gè)顯式ALGORITHM = UNDEFINED子句。\x0d\x0a· 為僅能用臨時(shí)表處理的視圖指定ALGORITHM = MERGE。在這種情況下,MySQL將生成告警,并將算法設(shè)置為UNDEFINED。\x0d\x0a正如前面所介紹的那樣,通過(guò)將視圖定義中的對(duì)應(yīng)部分合并到引用視圖的語(yǔ)句中,對(duì)MERGE進(jìn)行處理。在下面的示例中,簡(jiǎn)要介紹了MERGE的工作方式。在該示例中,假定有1個(gè)具有下述定義的視圖v_merge:\x0d\x0aCREATE ALGORITHM = MERGE VIEW v_merge (vc1, vc2) AS\x0d\x0aSELECT c1, c2 FROM t WHERE c3 100;\x0d\x0a\x0d\x0a示例1:假定發(fā)出了下述語(yǔ)句:\x0d\x0aSELECT * FROM v_merge;\x0d\x0a\x0d\x0aMySQL以下述方式處理語(yǔ)句:\x0d\x0a· v_merge成為t\x0d\x0a· *成為vc1、vc2,與c1、c2對(duì)應(yīng)\x0d\x0a· 增加視圖WHERE子句\x0d\x0a所產(chǎn)生的將執(zhí)行的語(yǔ)句為:\x0d\x0aSELECT c1, c2 FROM t WHERE c3 100;\x0d\x0a\x0d\x0a示例2:假定發(fā)出了下述語(yǔ)句:\x0d\x0aSELECT * FROM v_merge WHERE vc1 100) AND (c1
回答于?2022-11-16
什么是視圖?
視圖(view)是一種虛擬存在的表,是一個(gè)邏輯表,本身并不包含數(shù)據(jù)。作為一個(gè)select語(yǔ)句保存在數(shù)據(jù)字典中的。
通過(guò)視圖,可以展現(xiàn)基表(用來(lái)創(chuàng)建視圖的表)的部分?jǐn)?shù)據(jù);視圖數(shù)據(jù)來(lái)自定義視圖的查詢中使用的表,使用視圖動(dòng)態(tài)生成。
為什么要使用視圖?因?yàn)橐晥D的諸多優(yōu)點(diǎn),如下:
1)簡(jiǎn)單:使用視圖的用戶完全不需要關(guān)心后面對(duì)應(yīng)的表的結(jié)構(gòu)、關(guān)聯(lián)條件和篩選條件,對(duì)用戶來(lái)說(shuō)已經(jīng)是過(guò)濾好的復(fù)合條件的結(jié)果集。
2)安全:使用視圖的用戶只能訪問(wèn)他們被允許查詢的結(jié)果集,對(duì)表的權(quán)限管理并不能限制到某個(gè)行某個(gè)列,但是通過(guò)視圖就可以簡(jiǎn)單的實(shí)現(xiàn)。
3)數(shù)據(jù)獨(dú)立:一旦視圖的結(jié)構(gòu)確定了,可以屏蔽表結(jié)構(gòu)變化對(duì)用戶的影響,源表增加列對(duì)視圖沒(méi)有影響;源表修改列名,則可以通過(guò)修改視圖來(lái)解決,不會(huì)造成對(duì)訪問(wèn)者的影響。
總而言之,使用視圖的大部分情況是為了保障數(shù)據(jù)安全性,提高查詢效率。
為了不影響其他的數(shù)據(jù)庫(kù)表,新建一張數(shù)據(jù)庫(kù)表t_worker_info,代碼如下:createtablet_worker_info(idint(8)primarykeynotnullauto_increment,w_idint(10)notnull,w_namevarchar(20)notnull,w_ageint(3),w_sexvarchar(10),w_birthvarchar(20));創(chuàng)建t_worker_info后,查看一下數(shù)據(jù)結(jié)構(gòu),代碼如下:desct_worker_info;雙擊選中的數(shù)據(jù)庫(kù),在Views鼠標(biāo)右鍵“CreateView”,打開(kāi)編輯窗口,并在窗口中輸入代碼,代碼如下:CREATEVIEW`view_worker_info`ASSELECT*FROMt_worker_info;查看創(chuàng)建視圖的基本信息,利用desc或describe語(yǔ)句,代碼如下:descview_worker_info;查看視圖信息,如存儲(chǔ)引擎、數(shù)據(jù)長(zhǎng)度等,如果上述指標(biāo)都為null,說(shuō)明視圖是虛表,代碼如下:showtablestatuslike'view_worker_info';查看創(chuàng)建視圖的詳細(xì)信息,需要用到showcreateview視圖名,代碼如下:showcreateviewview_worker_info;
在查詢頁(yè)面用語(yǔ)句創(chuàng)建就可以。
1、打開(kāi)Navicat for MySQL,并登錄到指定數(shù)據(jù)庫(kù)。
2、點(diǎn)擊上方查詢。
3、點(diǎn)擊新建查詢。
4、在空白處寫(xiě)上視圖創(chuàng)建語(yǔ)句,點(diǎn)擊左上方執(zhí)行即可。
1) mysql show table status where comment='view';
(說(shuō)明:Mysql5.1支持視圖,視圖被看作一種抽象表,因此顯示視圖狀態(tài)的語(yǔ)句與顯示表狀態(tài)的語(yǔ)句相同,只是在comment列中以‘view’區(qū)分)
2) mysql select * from information_schema.tables where table_schema='yourDatabaseName' and table_type='view';
(說(shuō)明:這種方法通過(guò)系統(tǒng)表查找,效果同上,顯示信息更詳細(xì)。如果不能正確顯示結(jié)果,可能是大小寫(xiě)的問(wèn)題,Mysql在不同系統(tǒng)平臺(tái)不同配置參數(shù)下的顯示結(jié)果可能不同,注意這點(diǎn)。)