十年網(wǎng)站開發(fā)經(jīng)驗 + 多家企業(yè)客戶 + 靠譜的建站團(tuán)隊
量身定制 + 運(yùn)營維護(hù)+專業(yè)推廣+無憂售后,網(wǎng)站問題一站解決
show full tables from 數(shù)據(jù)庫名 [like 'pattern']
成都創(chuàng)新互聯(lián)-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價比平塘網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式平塘網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋平塘地區(qū)。費用合理售后完善,十多年實體公司更值得信賴。
"[]"表示可選的, like后面跟的是表名的模糊查詢,.
舉例:
一個視圖的名字叫v_user, SQL語句可以寫為show full tables from 數(shù)據(jù)庫名 like '%v_user%';
MySQL查詢視圖
使用示例
使用示例
使用示例
檢查選項的使用
mysql是可以基于視圖創(chuàng)建視圖,它會檢查視圖所依賴的視圖的規(guī)則
如果再基于v2創(chuàng)建視圖v3,v3沒有定義檢查選項,則此時向v3中插入數(shù)據(jù)時,不會檢查是否滿足v3的條件,但是會檢查是否滿足v2和v1的條件
local選項相比于cascaded,不會自動向上添加選項
如創(chuàng)建一個視圖,此時視圖中只包含一條數(shù)據(jù)
例如,現(xiàn)要查詢每個學(xué)生選修的課程(多對多,三張表),將SQL保存到視圖,以后再想查詢,直接select * from 視圖即可
進(jìn)入mysql后,你要進(jìn)入你的操作庫,然后再看表或者視圖,例子如下:
mysql show databases;
上面是現(xiàn)實庫,假設(shè)你的庫是ABC
mysqluse ABC;
上面的意思是使用ABC庫,也就是當(dāng)前的操作庫是ABC
mysqlshow tables;
上面的意思是顯示ABC庫中表和視圖
可以通過select查詢視圖的方式,來判斷視圖是否存在。
--1.假設(shè)現(xiàn)在新建一個視圖
create or replace force view test_view as
select * from dept;
--2.通過count(1)查出來的是,該視圖中記錄的總條數(shù)
select count(1) from test_view;
--3.如果要判斷該視圖是否存在,直接查看該視圖中的內(nèi)容即可
select * from test_view;
-- 如果有字段等內(nèi)容,說明視圖是存在的。反之,無法成功編譯,因為視圖不存在。
一.視圖概述
視圖是一個虛擬表,其內(nèi)容由查詢定義。同真實的表一樣,視圖包含一系列帶有名稱的列和行數(shù)據(jù)。但是,視圖并不在數(shù)據(jù)庫中以存儲的數(shù)據(jù)值集形式存在。行和列數(shù)據(jù)來自由定義視圖的查詢所引用的表,并且在引用視圖時動態(tài)生成。
對其中所引用的基礎(chǔ)表來說,視圖的作用類似于篩選。定義視圖的篩選可以來自當(dāng)前或其它數(shù)據(jù)庫的一個或多個表,或者其它視圖。通過視圖進(jìn)行查詢沒有任何限制,通過它們進(jìn)行數(shù)據(jù)修改時的限制也很少。
視圖是存儲在數(shù)據(jù)庫中的查詢的SQL 語句,它主要出于兩種原因:安全原因, 視圖可以隱藏一些數(shù)據(jù),如:社會保險基金表,可以用視圖只顯示姓名,地址,而不顯示社會保險號和工資數(shù)等,另一原因是可使復(fù)雜的查詢易于理解和使用。
視圖:查看圖形或文檔的方式。
視圖是從一個或多個表或視圖中導(dǎo)出的表,其結(jié)構(gòu)和數(shù)據(jù)是建立在對表的查詢基礎(chǔ)上的。和表一樣,視圖也是包括幾個被定義的數(shù)據(jù)列和多個數(shù)據(jù)行,但就本質(zhì)而言這些數(shù)據(jù)列和數(shù)據(jù)行來源于其所引用的表。
所以視圖不是真實存在的基礎(chǔ)表而是一張?zhí)摫?,視圖所對應(yīng)的數(shù)據(jù)并不實際地以視圖結(jié)構(gòu)存儲在數(shù)據(jù)庫中,而是存儲在視圖所引用的表中。
視圖一經(jīng)定義便存儲在數(shù)據(jù)庫中,與其相對應(yīng)的數(shù)據(jù)并沒有像表那樣又在數(shù)據(jù)庫中再存儲一份,通過視圖看到的數(shù)據(jù)只是存放在基本表中的數(shù)據(jù)。對視圖的操作與對表的操作一樣,可以對其進(jìn)行查詢、修改(有一定的限制)、刪除。
當(dāng)對通過視圖看到的數(shù)據(jù)進(jìn)行修改時,相應(yīng)的基本表的數(shù)據(jù)也要發(fā)生變化,同時,若基本表的數(shù)據(jù)發(fā)生變化,則這種變化也可以自動地反映到視圖中。
為了不影響其他的數(shù)據(jù)庫表,新建一張數(shù)據(jù)庫表t_worker_info,代碼如下:
create table t_worker_info(
id int(8) primary key not null auto_increment,
w_id int(10) not null,
w_name varchar(20) not null,
w_age int(3),
w_sex varchar(10),
w_birth varchar(20)
);
如下圖所示:
創(chuàng)建t_worker_info后,查看一下數(shù)據(jù)結(jié)構(gòu),代碼如下:
desc t_worker_info;
如下圖所示:
雙擊選中的數(shù)據(jù)庫,在Views鼠標(biāo)右鍵“Create View...”,打開編輯窗口,并在窗口中輸入代碼,代碼如下:
CREATE VIEW `view_worker_info` AS
SELECT * FROM t_worker_info;
如下圖所示:
查看創(chuàng)建視圖的基本信息,利用desc或describe語句,代碼如下:
desc view_worker_info;
如下圖所示:
查看視圖信息,如存儲引擎、數(shù)據(jù)長度等,如果上述指標(biāo)都為null,說明視圖是虛表,代碼如下:
show table status like 'view_worker_info';
如下圖所示:
6
查看創(chuàng)建視圖的詳細(xì)信息,需要用到show create view 視圖名,代碼如下:
show create view view_worker_info;