亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

淺談MySql 視圖、觸發(fā)器以及存儲(chǔ)過(guò)程

瀏覽:103日期:2023-10-14 13:53:31

視圖

什么是視圖?視圖的作用是什么?

視圖(view)是一種虛擬存在的表,是一個(gè)邏輯表,它本身是不包含數(shù)據(jù)的。作為一個(gè)select語(yǔ)句保存在數(shù)據(jù)字典中的。

通過(guò)視圖,可以展現(xiàn)基表(用來(lái)創(chuàng)建視圖的表叫做基表base table)的部分?jǐn)?shù)據(jù),說(shuō)白了視圖的數(shù)據(jù)就是來(lái)自于基表。

視圖的優(yōu)點(diǎn):

簡(jiǎn)單:使用視圖的用戶(hù)完全不需要關(guān)心后面對(duì)應(yīng)的表的結(jié)構(gòu)、關(guān)聯(lián)條件和篩選條件,對(duì)用戶(hù)來(lái)說(shuō)已經(jīng)是過(guò)濾好的復(fù)合條件的結(jié)果集。 安全:使用視圖的用戶(hù)只能訪問(wèn)他們被允許查詢(xún)的結(jié)果集,對(duì)表的權(quán)限管理并不能限制到某個(gè)行某個(gè)列,但是通過(guò)視圖就可以簡(jiǎn)單的實(shí)現(xiàn)。 數(shù)據(jù)獨(dú)立:一旦視圖的結(jié)構(gòu)確定了,可以屏蔽表結(jié)構(gòu)變化對(duì)用戶(hù)的影響,源表增加列對(duì)視圖沒(méi)有影響;源表修改列名,則可以通過(guò)修改視圖來(lái)解決,不會(huì)造成對(duì)訪問(wèn)者的影響。 不占用空間:視圖是邏輯上的表,不占用內(nèi)存空間​。

總而言之,使用視圖的大部分情況是為了保障數(shù)據(jù)安全性,提高查詢(xún)效率。

視圖的缺點(diǎn):

性能差:sql server 必須把視圖查詢(xún)轉(zhuǎn)化成對(duì)基本表的查詢(xún),如果這個(gè)視圖是由一個(gè)復(fù)雜的多表查詢(xún)所定義,那么,即使是視圖的一個(gè)簡(jiǎn)單查詢(xún),sql server 也要把它變成一個(gè)復(fù)雜的結(jié)合體,需要花費(fèi)一定的時(shí)間。 修改限制:當(dāng)用戶(hù)試圖修改試圖的某些信息時(shí),數(shù)據(jù)庫(kù)必須把它轉(zhuǎn)化為對(duì)基本表的某些信息的修改,對(duì)于簡(jiǎn)單的試圖來(lái)說(shuō),這是很方便的,但是,對(duì)于比較復(fù)雜的試圖,可能是不可修改的。

視圖的創(chuàng)建以及修改

--創(chuàng)建的基本語(yǔ)法是:create view <視圖名稱(chēng)> as select 語(yǔ)句;create view <視圖名稱(chēng)> (字段) as select 語(yǔ)句;create or replace view <視圖名稱(chēng)>;--修改的語(yǔ)法是:alter view <視圖名稱(chēng)> as select 語(yǔ)句;--視圖刪除語(yǔ)法:drop view <視圖名稱(chēng)> ;

觸發(fā)器

什么是觸發(fā)器?

觸發(fā)器就是監(jiān)視某種情況,并觸發(fā)某種操作。

創(chuàng)建、刪除觸發(fā)器的語(yǔ)法:

--創(chuàng)建觸發(fā)器的語(yǔ)法:create trigger 觸發(fā)器名稱(chēng) after/before insert/update/delete on 表名 for each rowbeginsql語(yǔ)句;end--after/before:可以設(shè)置為事件發(fā)生前或后--insert/update/delete:它們可以在執(zhí)行insert、update或delete的過(guò)程中觸發(fā)--for each row:每隔一行執(zhí)行一次動(dòng)作--刪除觸發(fā)器的語(yǔ)法:drop trigger 觸發(fā)器名稱(chēng);

演示

--創(chuàng)建一個(gè)員工遲到表:create table work_time_delay(empno int not null comment ’雇員編號(hào)’,ename varchar(50) comment ’雇員姓名’,status int comment ’狀態(tài)’);--delimiter // 自定義語(yǔ)句的結(jié)束符號(hào)​delimiter //create trigger trig_work after insert on work_time_delayfor each rowbegin update employee set sal=sal-100 where empno=new.empno;end//--new:指的是事件發(fā)生before或者after保存的新數(shù)據(jù)

存儲(chǔ)過(guò)程

什么是存儲(chǔ)過(guò)程?

存儲(chǔ)過(guò)程就是把復(fù)雜的一系列操作,封裝成一個(gè)過(guò)程。類(lèi)似于 shell,python 腳本等。

存儲(chǔ)過(guò)程的優(yōu)點(diǎn):

復(fù)雜操作,調(diào)用簡(jiǎn)單 速度快

存儲(chǔ)過(guò)程的缺點(diǎn):

封裝復(fù)雜 沒(méi)有靈活性

創(chuàng)建存儲(chǔ)過(guò)程語(yǔ)法

--創(chuàng)建存儲(chǔ)過(guò)程語(yǔ)法:create procedure 名稱(chēng) (參數(shù)....)begin 過(guò)程體; 過(guò)程體;end--參數(shù):-- in|out|inout 參數(shù)名稱(chēng) 類(lèi)型(長(zhǎng)度)-- in:表示調(diào)用者向過(guò)程傳入值(傳入值可以是字面量或變量)-- out:表示過(guò)程向調(diào)用者傳出值(可以返回多個(gè)值)(傳出值只能是變量)-- inout:既表示調(diào)用者向過(guò)程傳入值,又表示過(guò)程向調(diào)用者傳出值(值只能是變量)--聲明變量:declare 變量名 類(lèi)型(長(zhǎng)度) default 默認(rèn)值;--給變量賦值:set @變量名=值;--調(diào)用存儲(chǔ)命令:call 名稱(chēng)(@變量名);--刪除存儲(chǔ)過(guò)程命令:drop procedure 名稱(chēng);--查看創(chuàng)建的存儲(chǔ)過(guò)程命令:show create procedure 名稱(chēng)G;

演示

--創(chuàng)建一個(gè)簡(jiǎn)單的存儲(chǔ)過(guò)程:delimiter //create procedure name(in n int)begin select * from employee limit n;end//--調(diào)用存儲(chǔ)過(guò)程set @n=5;//call name(@n);create procedure name()begin declare n int default 6; select * from employee limit n;end//--調(diào)用存儲(chǔ)過(guò)程call name();//

以上就是淺談MySql 視圖、觸發(fā)器以及存儲(chǔ)過(guò)程的詳細(xì)內(nèi)容,更多關(guān)于MySql 視圖、觸發(fā)器以及存儲(chǔ)過(guò)程的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: MySQL 數(shù)據(jù)庫(kù)
相關(guān)文章:
主站蜘蛛池模板: 99久久免费精品高清特色大片 | 免费特级黄毛片在线成人观看 | 黄色小视频在线观看免费 | 久久久久久九九 | 日韩小视频在线播放 | 国产片网站 | 国产伊人影院 | 毛片网站大全 | 日本人视频18jizz免费 | 国产一级精品毛片 | wwwwww黄| 精品福利视频在线观看视频 | 国产乱码精品一区二区三区网页版 | 免费久福利视频在线观看 | 处初女处夜情视频在线观看 | 精品福利一区二区三区免费视频 | 成年做羞羞免费观看视频网站 | 国产精品亚洲二区 | 131美女爽爽爽爱做视频 | 91小视频在线 | 一级一毛片 | 视频办公室添的我好爽 | 日韩不卡中文字幕 | 91无套极品外围在线播放 | 亚洲永久视频 | www午夜视频 | 国内真实实拍伦视频在线观看 | 国产精品久久久久毛片 | 日本一级网站 | 国产亚洲精品资源一区 | 日日麻批免费视频播放 | 大陆三级特黄在线播放 | 免费视频成人国产精品网站 | 婷婷中文在线 | 亚洲人成网站在线观看播放青青 | 国产三级网站在线观看 | 爱久久久国产精品 | 欧美大片天天免费看视频 | 尤物视频免费在线观看 | jizzxxxx中国 | 日韩精品第一区 |