前言
視圖是數(shù)據(jù)庫系統(tǒng)中一種非常有用的數(shù)據(jù)庫對象。MySQL 5.0 之后的版本添加了對視圖的支持。
認識視圖
視圖是一個虛擬表,其內容由查詢定義。同真實表一樣,視圖包含一系列帶有名稱的列和行數(shù)據(jù),但視圖并不是數(shù)據(jù)庫真實存儲的數(shù)據(jù)表。
視圖是從一個、多個表或者視圖中導出的表,包含一系列帶有名稱的數(shù)據(jù)列和若干條數(shù)據(jù)行。
視圖并不同于數(shù)據(jù)表,它們的區(qū)別在于以下幾點:
視圖與表在本質上雖然不相同,但視圖經(jīng)過定義以后,結構形式和表一樣,可以進行查詢、修改、更新和刪除等操作。
1、準備工作
在MySQL數(shù)據(jù)庫中創(chuàng)建兩張表balance(余額表)和customer(客戶表)并插入數(shù)據(jù)。
create table customer( id int(10) primary key, name char(20) not null, role char(20) not null, phone char(20) not null, sex char(10) not null, address char(50) not null )ENGINE=InnoDB DEFAULT CHARSET=utf8; #外鍵為customerId create table balance( id int(10) primary key, customerId int(10) not null, balance DECIMAL(10,2), foreign key(customerId) references customer(id) )ENGINE=InnoDB DEFAULT CHARSET=utf8;
向客戶表和余額表中各插入3條數(shù)據(jù)。
insert into customer values(0001,"xiaoming",'vip1','12566666','male','江寧區(qū)888號'); insert into customer values(0002,"xiaohong",'vip10','15209336760','male','建鄴區(qū)888號'); insert into customer values(0003,"xiaocui",'vip11','15309336760','female','新街口888號'); insert into balance values(1,0001,900.55); insert into balance values(2,0002,900.55); insert into balance values(3,0003,10000);
2、視圖簡介
視圖可以簡單理解成虛擬表,它和數(shù)據(jù)庫中真實存在數(shù)據(jù)表不同,視圖中的數(shù)據(jù)是基于真實表查詢得到的。視圖和真實表一樣具備相似的結構。真實表的更新,查詢,刪除等操作,視圖也支持。那么為什么需要視圖呢?
a、提升真實表的安全性:視圖是虛擬的,可以只授予用戶視圖的權限而不授予真實表的權限,起到保護真實表的作用。
b、定制化展示數(shù)據(jù):基于同樣的實際表,可以通過不同的視圖來向不同需求的用戶定制化展示數(shù)據(jù)。
c、簡化數(shù)據(jù)操作:適用于查詢語句比較復雜使用頻率較高的場景,可以通過視圖來實現(xiàn)。
......
需要說明一點的是:視圖相關的操作需要用戶具備相應的權限。以下操作使用root用戶,默認用戶具備操作權限。
創(chuàng)建視圖語法
create view 視圖名稱> as select語句>;
修改視圖語法
修改視圖名稱可以先刪除,再用相同的語句創(chuàng)建。
#更新視圖結構 alter view 視圖名稱> as select語句>; #更新視圖數(shù)據(jù)相當于更新實際表,不適用基于多表創(chuàng)建的視圖 update ....
注意:部分視圖的數(shù)據(jù)是無法更新,也就是無法使用update,insert等語句更新,比如:
a、select語句包含多個表
b、視圖中包含having子句
c、試圖中包含distinct關鍵字
......
刪除視圖語法
drop view 視圖名稱>
3、視圖的操作
基于單表創(chuàng)建視圖
mysql> create view bal_view -> as -> select * from balance; Query OK, 0 rows affected (0.22 sec)
創(chuàng)建完成后,查看bal_view的結構和記錄。可以發(fā)現(xiàn)通過視圖查詢到數(shù)據(jù)和通過真實表查詢得到的結果完全一樣。
#查詢bal_view的結構 mysql> desc bal_view; +------------+---------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +------------+---------------+------+-----+---------+-------+ | id | int(10) | NO | | NULL | | | customerId | int(10) | NO | | NULL | | | balance | decimal(10,2) | YES | | NULL | | +------------+---------------+------+-----+---------+-------+ 3 rows in set (0.07 sec) #查詢bal_view中的記錄 mysql> select * from bal_view; +----+------------+----------+ | id | customerId | balance | +----+------------+----------+ | 1 | 1 | 900.55 | | 2 | 2 | 900.55 | | 3 | 3 | 10000.00 | +----+------------+----------+ 3 rows in set (0.01 sec)
通過創(chuàng)建視圖的語句不難得出結論:當真實表中的數(shù)據(jù)發(fā)生改變時,視圖中的數(shù)據(jù)也會隨之改變。那么當視圖中的數(shù)據(jù)發(fā)生改變時,真實表中的數(shù)據(jù)會變化嗎?來實驗一下,修改id=1的客戶balance為2000。
mysql> update bal_view set balance=2000 where id=1; Query OK, 1 row affected (0.05 sec) Rows matched: 1 Changed: 1 Warnings: 0
來看一下真實表balance中的數(shù)據(jù)。
mysql> select * from bal_view where id=1; +----+------------+---------+ | id | customerId | balance | +----+------------+---------+ | 1 | 1 | 2000.00 | +----+------------+---------+ 1 row in set (0.03 sec)
結論:視圖表中的數(shù)據(jù)發(fā)生變化時,真實表中的數(shù)據(jù)也會隨之改變。
基于多表創(chuàng)建視圖
創(chuàng)建視圖cus_bal,共兩個字段客戶名稱和余額。
mysql> create view cus_bal -> (cname,bal) -> as -> select customer.name,balance.balance from customer ,balance -> where customer.id=balance.customerId; Query OK, 0 rows affected (0.05 sec) #查看cus_bal中的數(shù)據(jù) mysql> select * from cus_bal; +----------+----------+ | cname | bal | +----------+----------+ | xiaoming | 2000.00 | | xiaohong | 900.55 | | xiaocui | 10000.00 | +----------+----------+ 3 rows in set (0.28 sec)
修改視圖
將cus_bal視圖中的cname改成cusname。
mysql> alter view cus_bal -> (cusname,bal) -> as -> select customer.name,balance.balance from customer ,balance -> where customer.id=balance.customerId; Query OK, 0 rows affected (0.06 sec) #查看修改后視圖結構。 mysql> desc cus_bal; +---------+---------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +---------+---------------+------+-----+---------+-------+ | cusname | char(20) | NO | | NULL | | | bal | decimal(10,2) | YES | | NULL | | +---------+---------------+------+-----+---------+-------+ 2 rows in set (0.00 sec)
修改基于多表創(chuàng)建的視圖
mysql> insert into cus_bal(cusname,bal) values ("ee",11); ERROR 1393 (HY000): Can not modify more than one base table through a join view 'rms.cus_bal'
刪除視圖
刪除視圖cus_bal
drop view cus_bal; mysql> drop view cus_bal; Query OK, 0 rows affected (0.00 sec)
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。
標簽:荊門 北京 昌都 梅河口 鄂爾多斯 黔西 駐馬店 陜西
巨人網(wǎng)絡通訊聲明:本文標題《MySQL視圖簡介及基本操作教程》,本文關鍵詞 MySQL,視圖,簡介,及,基本操作,;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。