什麼是檢視
有結構沒結果的臨時表
- 有結構意味著, 檢視是一個有行有列的二維表
- 沒結果意味著, 檢視中並沒有真實存放的資料
- 檢視中的資料, 從基表中獲取
檢視就是一個零庫存的經銷商
檢視的優點
- 可以複用程式碼, 節省SQL語句, 以後可以直接操作檢視
- 可以隔離表結構, 隱藏關鍵資料, 只向外提供必要的資料
- 檢視主要針對查詢, 刪除檢視, 不會影響資料
- 檢視可以把資料分級, 不同的許可權, 給不同的檢視(資料)
建立
建立檢視之前, 我們需要一些測試資料
data:image/s3,"s3://crabby-images/beb7b/beb7bcc28db104fb257698a3e6730a3f0f8d9d47" alt="image.png"
data:image/s3,"s3://crabby-images/66890/668909d586703d5502649d06f48d5d31e02f216c" alt="image.png"
drop database if exists new_library;
create database new_library CHARACTER set utf8;
use new_library;
drop table if exists readertype;
create table readertype(
retypeid int not null primary key,
typename VARCHAR(20) not null,
borrowquantity int not null,
borrowday int
);
drop table if exists reader;
create table reader(
readerid char(10) not null PRIMARY key,
readername VARCHAR(20) not null,
readerpass VARCHAR(20) not null,
retypeid int,
readerdate datetime,
readerstatus VARCHAR(4),
FOREIGN key(retypeid) REFERENCES readertype(retypeid)
);
insert into readertype values
(1,'學生',10,30),
(2,'教師',20,60),
(3,'管理員',15,30),
(4,'職工',15,20);
insert into reader values
('0016','蘇小東','123456',1,'1999-9-9','有效'),
('0017','張明','123456',1,'2010-9-10','有效'),
('0018','樑君紅','123456',1,'2010-9-10','有效'),
('0021','趙清遠','123456',2,'2010-7-1','有效'),
('0034','李瑞清','123456',3,'2009-8-3','有效'),
('0042','張明月','123456',4,'1997-4-23','有效');
複製程式碼
建立一個檢視, 用來查詢讀者的詳細資訊, 包括使用者id, 姓名, 類別名稱, 借書數量
如果不使用檢視, 我們可以使用連表查詢
data:image/s3,"s3://crabby-images/0043f/0043f691d3dcf8cd80a06f6cd0a3ab06d7321cde" alt="image.png"
有了檢視, 我們就可以把複雜的查詢放入檢視之中
drop view if exists reader_detail;
create view reader_detail as
select
readerid,readername,typename,borrowquantity
from
reader,readertype
where
reader.retypeid = readertype.retypeid;
複製程式碼
檢視檢視
因為檢視是一張虛擬表, 所有檢視錶的命令, 檢視都能用
show tables;
desc reader_detail;
show create table reader_detail;
複製程式碼
data:image/s3,"s3://crabby-images/5c5f2/5c5f2fd85e543a12441f2a3bb9e8aefffa9dc696" alt="image.png"
data:image/s3,"s3://crabby-images/42f9c/42f9cb69dfe3e68e7fa6d52b282e1a519d39918b" alt="image.png"
data:image/s3,"s3://crabby-images/3bc62/3bc6217ffa6d86aaaa5e86ad2e9fd761e077222f" alt="image.png"
data:image/s3,"s3://crabby-images/c5e21/c5e21951738a8f3368368ff743f244b64fcc0f4f" alt="image.png"
既然檢視是臨時表, 那必然會有結構檔案.frm
data:image/s3,"s3://crabby-images/f91a1/f91a1b75a7ce9cdd6c08b118a1d3b195ee7ce3cb" alt="image.png"
使用檢視
像表一樣查詢資料即可
data:image/s3,"s3://crabby-images/13219/13219615d4bba1958881eaa2a264f11213b6e934" alt="image.png"
修改檢視
可以使用alter
在原有檢視的基礎上, 加入欄位讀者狀態
data:image/s3,"s3://crabby-images/f71eb/f71ebfe685814c21f624e96b32a142c04c048be2" alt="image.png"
也可以使用create or replace
在另一個檢視中, 增加讀者姓名欄位
data:image/s3,"s3://crabby-images/50251/502519527f480133a7fab7fd2c3d6f9727430d41" alt="image.png"
刪除檢視
drop view 檢視名稱; -- 不能使用table
複製程式碼
data:image/s3,"s3://crabby-images/77aa6/77aa6279828ed8f130878d508daf1f5b49842e16" alt="image.png"
也可以一次刪除多個
drop view 檢視1, 檢視2....;
複製程式碼
檢視重新命名
rename table 原來的名字 to 新名字;
複製程式碼
data:image/s3,"s3://crabby-images/91805/918056898ca9315d4068e4766f3ea976c1bfb705" alt="image.png"
data:image/s3,"s3://crabby-images/17439/17439d419fe936370c412da33c1491ab1d83a7aa" alt="image.png"
檢視中的資料, 可以增刪改嗎?
可以, 但是不推薦這麼做, 檢視主要是查詢資料時使用
data:image/s3,"s3://crabby-images/7d0c7/7d0c7fa44b4db53e55ee82b3f163027397ad5cc9" alt="MySQL檢視.png"
因為不能操作多表, 所以我們新建一個單表的檢視
drop view if exists select_reader;
create view select_reader as select readerid,readername from reader;
複製程式碼
檢視進行insert操作
data:image/s3,"s3://crabby-images/5ebd5/5ebd55aa15042fab57bbe38cf902ce7bc8bded3e" alt="image.png"
向檢視中插入一條資料
insert into select_reader values(123,'LUCY');
複製程式碼
data:image/s3,"s3://crabby-images/a1203/a1203767b6562aaca94689813eb3b7d19627ad36" alt="image.png"
檢視進行update操作
data:image/s3,"s3://crabby-images/aa169/aa1693811c8e90f53b8219672cd222e687853a61" alt="image.png"
注意with check option
data:image/s3,"s3://crabby-images/2d9e2/2d9e29f8dac4fa44edc7ad62a194fc9bdafed3e0" alt="image.png"
檢視進行delete操作
data:image/s3,"s3://crabby-images/457af/457af2231cb9133ad225ae0fb42f10085fc9c1e6" alt="image.png"
data:image/s3,"s3://crabby-images/cb252/cb252ffcdac0242bb41d2da311a94909b77a72d4" alt="image.png"