用建視圖的用戶登陸,執(zhí)行下面代碼,可以刪除所有視圖,但是慎重哈。
田陽(yáng)網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)建站!從網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開(kāi)發(fā)、APP開(kāi)發(fā)、成都響應(yīng)式網(wǎng)站建設(shè)公司等網(wǎng)站項(xiàng)目制作,到程序開(kāi)發(fā),運(yùn)營(yíng)維護(hù)。創(chuàng)新互聯(lián)建站從2013年成立到現(xiàn)在10年的時(shí)間,我們擁有了豐富的建站經(jīng)驗(yàn)和運(yùn)維經(jīng)驗(yàn),來(lái)保證我們的工作的順利進(jìn)行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)建站。
前提是該用戶有執(zhí)行代碼權(quán)限。
begin
for cur in (select view_name from user_views) loop
execute immediately 'drop view '|| cur.view_name ||';';
end loop;
end;
/
首先,要明白視圖的原理。\r\n視圖的數(shù)據(jù)都產(chǎn)生于表,視圖本身是沒(méi)有數(shù)據(jù)的,而表才是真正的數(shù)據(jù)來(lái)源。\r\n還有多級(jí)的視圖,就是從視圖還可以繼續(xù)創(chuàng)建視圖。\r\n所以,視圖的數(shù)據(jù)來(lái)源是表或視圖。但是最終的數(shù)據(jù)源一定是表。\r\n什么樣的視圖數(shù)據(jù)是可以使用DELETE的?只有從單表引過(guò)來(lái)的視圖是可以的,這樣的視圖操作實(shí)際就相當(dāng)于操作表,但是DROP VIEW不會(huì)對(duì)數(shù)據(jù)有任何影響。其他形勢(shì)的視圖,都是不可能刪除數(shù)據(jù)的。但是DROP VIEW同樣可以。\r\n視圖只是根據(jù)關(guān)聯(lián)關(guān)系從表中抓取數(shù)據(jù)。實(shí)際并沒(méi)有像表一樣有專門的存儲(chǔ)這些數(shù)據(jù)。只是從表里引過(guò)來(lái)而已。只要你時(shí)刻記住,視圖實(shí)際上并沒(méi)有實(shí)際的存儲(chǔ)數(shù)據(jù),而是借用表的數(shù)據(jù),這就夠了。無(wú)論你創(chuàng)建或者刪除視圖,都不會(huì)影響數(shù)據(jù)本身。否則你想想,你創(chuàng)建了一個(gè)視圖的時(shí)候,沒(méi)想過(guò)為什么一下子就有了那么多數(shù)據(jù)了呢?也不是你插入的,因?yàn)榫褪菑谋硪^(guò)來(lái)的而已。\r\n刪除視圖的語(yǔ)句是DROP VIEW 視圖名字\r\n所以刪除視圖,不會(huì)對(duì)數(shù)據(jù)有任何影響。因?yàn)閿?shù)據(jù)都在表中。想要恢復(fù)視圖,重新創(chuàng)建,你的幾千萬(wàn)條數(shù)據(jù)就又會(huì)出現(xiàn)了。視圖的效果和SELECT查詢一樣,只是能把這個(gè)查詢固定了,以便你直接拿來(lái)用。
該表中的數(shù)據(jù)時(shí)oracle 為了同步基表和物化視圖之間的數(shù)據(jù)的 當(dāng)基表的數(shù)據(jù)發(fā)生變化 在日志表中就會(huì)產(chǎn)生數(shù)據(jù)。 等oracle將變化同步到物化視圖后 日志表中的數(shù)據(jù)會(huì)自動(dòng)清除 一般情況下不建議手工刪除該表中的數(shù)據(jù)