MySQL視圖的概念、創(chuàng)建、查看、刪除和修改詳解
一、什么是視圖
小學(xué)的時候,每年都會舉辦一次抽考活動,意思是從每一個班級里面篩選出幾個優(yōu)秀的同學(xué)去參加考試。這時候很多班級篩選出來的這些同學(xué)就可以臨時組成一個班級,如果我們把每一個班級都當(dāng)做是一張真實的表,這個臨時的班級在數(shù)據(jù)庫里就可以當(dāng)做一個視圖,也就是說,這個臨時的班級其實不是真實存在的,當(dāng)考試過后,這些學(xué)生還是各回各家各找各媽。。。。
視圖是從一個或多個表中導(dǎo)出來的表,是一種虛擬存在的表。視圖就像一個窗口,通過這個窗口可以看到系統(tǒng)專門提供的數(shù)據(jù),這樣用戶可以不看整個數(shù)據(jù)庫表中的數(shù)據(jù),而只關(guān)心對自己有用的數(shù)據(jù)。視圖可以使用戶的操作更方便,而且可以保障數(shù)據(jù)庫系統(tǒng)的安全性。
二、創(chuàng)建視圖
1.在單表上創(chuàng)建視圖
雖然視圖可以被看成是一種虛擬表,但是其物理上是不存在的,即MySQL并沒有專門的位置為視圖存儲數(shù)據(jù)。根據(jù)視圖的概念可以發(fā)現(xiàn)其數(shù)據(jù)來源于查詢語句,因此創(chuàng)建視圖的基本語法為:
CREATE[OR REPLACE] VIEW viewname[(columnlist)] AS SELECT statement
CREATE表示創(chuàng)建新的視圖;REPLACE表示替換已經(jīng)創(chuàng)建的視圖;[(columnlist)]表示可以顯示的指出視圖中有哪些列(必須和select語句對應(yīng));viewname為視圖的名稱;columnlist為屬性列;SELECT statement表示SELECT語句;
注意! 創(chuàng)建視圖需要登陸用戶有相應(yīng)的權(quán)限,查看權(quán)限方法:
select user,Select_priv,Create_view_priv from mysql.user;
例如在下面學(xué)生表上面創(chuàng)建視圖
創(chuàng)建視圖SQL語句示例
create view view_student as select id,name ,class_id,sex from student;
查看視圖
通過視圖可以檢索數(shù)據(jù)
視圖本身相當(dāng)于一個窗口,通過這個窗口我們也可以修改數(shù)據(jù)
update view_student set name='小王王' where name='小王';
2.在多表上創(chuàng)建視圖
CREATE[OR REPLACE] VIEW viewname[columnlist] AS SELECT statement
- CREATE表示創(chuàng)建新的視圖;
- REPLACE表示替換已經(jīng)創(chuàng)建的視圖;
- viewname為視圖的名稱;
- columnlist為屬性列;
- SELECT statement表示SELECT語句。與單表上創(chuàng)建視圖不同的是,SELECT子句是涉及到多表的聯(lián)合查詢語句。
例如在下面教師表和學(xué)生表之間創(chuàng)建視圖
SQL語句 (視圖不允許有列名重復(fù),所以這里的class.id和student.id要起別名
create view view_student_teacher as select class.id as teacher_id,teacher,class,student.id,student.name,sex from class left join student on class.id=student.class_id;
三、查看視圖
創(chuàng)建完視圖后,像表一樣,我們經(jīng)常需要查看視圖信息。在MySQL中,有許多可以實現(xiàn)查看視圖的語句,如DESCRIBE、SHOW TABLES、SHOW CREATE VIEW。如果要使用這些語句,首先要確保擁有SHOW VIEW的權(quán)限。
1.使用DESCRIBE | DESC語句查看視圖基本信息
視圖也是一張表,只是這張表比較特殊,是一張?zhí)摂M的表,所以同樣可以使用DESCRIBE語句來查看視圖的基本定義。DESCRIBE語句查看視圖的語法如下:
DESCRIBE | DESC viewname;
例如查看上面創(chuàng)建的視圖
2.使用SHOW TABLES語句查看視圖基本信息
從MySQL 5.1版本開始,執(zhí)行SHOW TABLES語句時不僅會顯示表的名字,同時也會顯示視圖的名字。
show tables
3.使用 show create view/table 語句查看視圖創(chuàng)建信息
SHOW CREATE TABLE|VIEW viewname;
四、更新視圖數(shù)據(jù)
更新視圖是指通過視圖來插入(INSERT)、更新(UPDATE)和刪除(DELETE)表中的數(shù)據(jù)。因為視圖實質(zhì)是一個虛擬表,其中沒有數(shù)據(jù),通過視圖更新時都是轉(zhuǎn)換到基本表更新。更新視圖時,只能更新權(quán)限范圍內(nèi)的數(shù)據(jù),超出范圍就不能更新了。
update view_student set name='小王' where name='小王王';
不能更新的情況:
- 視圖中包含SUM()、COUNT()、MAX()和MIN()等函數(shù);
- 視圖中包含UNION、UNION ALL、DISTINCT、GROUP BY和HAVING等關(guān)鍵字;
- 視圖對應(yīng)的表存在沒有默認(rèn)值的列,而且該列沒有包含在視圖里;
- 包含子查詢的視圖;
- 其他特殊情況;
例如更改view_student_teacher時
五、修改視圖
修改視圖是指修改數(shù)據(jù)庫中存在的視圖,當(dāng)基本表的某些字段發(fā)生變化的時候,可以通過修改視圖來保持與基本表的一致性。ALTER語句來修改視圖。
ALTER VIEW viewname[columnlist] AS SELECT statement
這個語法中的所有關(guān)鍵字和參數(shù)除了alter 外,其他都和創(chuàng)建視圖是一樣的。
例如修改視圖view_student_teacher
SQL語句示例
alter view view_student_teacher as select teacher,class,name,sex from class left join student on class.id=student.class_id;
注意,當(dāng)真實表中修改了某個存在視圖中的字段時,這個視圖也需要跟著變,否則會變成無效的視圖
例如,修改了student表中的name字段
alter table student change column name name1 varchar(64); select * from view_student_teaccher;
這時候就需要將視圖也跟著修改
alter view view_student_teacher as select teacher,class,name1,sex from class left join student on class.id=student.class_id;
六、刪除視圖
刪除視圖是指刪除數(shù)據(jù)庫中已存在的視圖。刪除視圖時,只能刪除視圖的定義,不會刪除數(shù)據(jù)。
在MySQL中,可使用DROP VIEW語句來刪除視圖,但是用戶必須擁有DROP權(quán)限。刪除視圖的語法如下:
DROP VIEW viewname [,viewnamen];
參數(shù)viewname表示所要刪除視圖的名稱,可同時指定刪除多個視圖。
總結(jié)
到此這篇關(guān)于MySQL視圖的概念、創(chuàng)建、查看、刪除和修改的文章就介紹到這了,更多相關(guān)MySQL視圖創(chuàng)建 查看 刪除和修改內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MySQL數(shù)據(jù)庫表分區(qū)注意事項大全【推薦】
這篇文章主要介紹了MySQL數(shù)據(jù)庫表分區(qū)注意事項相關(guān)內(nèi)容,比較全面,這里分享給大家,需要的朋友可以參考。2017-10-10MySQL聯(lián)合索引與最左匹配原則的實現(xiàn)
最左匹配原則在我們MySQL開發(fā)過程中和面試過程中經(jīng)常遇到,為了加深印象和理解,我在這里把MySQL的最左匹配原則詳細(xì)的講解一下,感興趣的可以了解一下2023-12-12MySQL創(chuàng)建用戶以及用戶權(quán)限詳細(xì)圖文教程
在MySQL中可以通過創(chuàng)建用戶來管理數(shù)據(jù)庫的訪問權(quán)限,下面這篇文章主要給大家介紹了關(guān)于MySQL創(chuàng)建用戶以及用戶權(quán)限的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2024-06-06MYSQL出現(xiàn)" Client does not support authentication "的
MYSQL出現(xiàn)" Client does not support authentication "的解決方法...2007-06-06