亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MySQL自定義函數(shù)及觸發(fā)器

 更新時間:2022年08月04日 09:15:55   作者:Java學(xué)術(shù)趴  
這篇文章主要介紹了MySQL自定義函數(shù)及觸發(fā)器,自定義函數(shù)是一種對MySQL擴(kuò)展的途徑,其用法與內(nèi)置的函數(shù)相同,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值,需要的朋友可以參考一下

1. 存儲函數(shù)(自定義函數(shù))

  • 自定義函數(shù)是一種對MySQL擴(kuò)展的途徑,其用法與內(nèi)置的函數(shù)相同。
  • 定義函數(shù)的兩個必要條件:參數(shù)、返回值。函數(shù)可以返回任意類型的值,同樣可以接收這些類型的參數(shù)。

關(guān)于函數(shù)體:

  • 函數(shù)體是由合法的SQL語句構(gòu)成。
  • 函數(shù)體可以是簡單的SELECT或INSERT語句。
  • 函數(shù)體如果為符合結(jié)構(gòu)則使用BEGIN....AND語句包裹。
  • 復(fù)合結(jié)構(gòu)可以包含聲明、循環(huán)、控制結(jié)構(gòu)等等。

重點:自定義的函數(shù)不能重名,類似于定義了一個全局變量,變量名不能一致。

1.1 定義存儲函數(shù)

語法格式:

create function 函數(shù)名(參數(shù)列表)
returns type(返回值類型)
begin
    --SQL語句
end;

需求:定義一個存儲過程的函數(shù),獲取滿足條件的總記錄條數(shù)

實現(xiàn):

delimiter $
create function fun(countryId int)
returns int 
begin
    # 定義一個存儲總數(shù)據(jù)條數(shù)的變量
    declare cum int default 0;
    # 查詢等于傳遞參數(shù)的全部的數(shù)據(jù)數(shù),然后將其賦值給定義的變量
 ? ?select count(*) into cum from city where country_id = countryId;
 ? ?# 返回結(jié)果值。存儲函數(shù)必須有返回值
 ? ?return cum;
end $

delimiter ;

1.2 調(diào)用存儲函數(shù)

語法格式:

select 函數(shù)名(參數(shù)列表);

注意:調(diào)用存儲過程的時候使用的是call關(guān)鍵字,但是在調(diào)用存儲函數(shù)的時候直接使用select即可,就和調(diào)用MySQL一個普通的聚合函數(shù)的方式一樣即可。

select fun(1);
# 這里和存儲過程一樣,調(diào)用的時候需要加小括號和參數(shù),但是在刪除的時候指定函數(shù)名即可

1.3 刪除存儲函數(shù)

語法格式

drop [if exists] function fun;

2. 觸發(fā)器

2.1 觸發(fā)器介紹

  • 觸發(fā)器是與表有關(guān)的數(shù)據(jù)庫對象,指在 insert/update/delete 之前或之后,觸發(fā)并執(zhí)行觸發(fā)器中定義的SQL集合。觸發(fā)器的這種特性可以協(xié)助應(yīng)用在數(shù)據(jù)庫端確保數(shù)據(jù)的完整性、日志記錄以及數(shù)據(jù)校驗等操作。
  • 只有增加、刪除、修改的時候才可以使用觸發(fā)器,查詢的時候不可以使用觸發(fā)器。
  • 使用別名OLD和NEW來引用觸發(fā)器中發(fā)生變化的記錄內(nèi)容,這與其他的數(shù)據(jù)庫是相似對的。MySQL觸發(fā)器還只支持行級觸發(fā),不支持語句級觸發(fā)。oracle支持行級和語句級觸發(fā)器都支持。
  • OLD、NEW這兩個變量又叫做行記錄變量。可以通過這個兩個變量來獲取即將要操作的數(shù)據(jù)表中的數(shù)據(jù)。

2.2 創(chuàng)建觸發(fā)器

語法格式:

create trigger(觸發(fā)器) trigger_name(觸發(fā)器名稱)
before/after insert/update/delete
on tab_name(表名)
[for each row](行級觸發(fā)器)
begin
    trigger_stmt;(觸發(fā)器的邏輯)
end;

需求:通過觸發(fā)器記錄 emp 表的數(shù)據(jù)變更日志 emp_logs ,其中包含增加、修改、刪除

實現(xiàn):

分析:一個觸發(fā)器只能操作一種數(shù)據(jù)的操作類型,不可以同時完成增加、修改、刪除的操作。所以此時需要定義多個觸發(fā)器來完成這個日志記錄的任務(wù)。

因為 MySQL中是行級操作的觸發(fā)器,所以 new 以及 old 中存儲的都是一整行數(shù)據(jù)。

創(chuàng)建執(zhí)行 insert 的觸發(fā)器:

  • 使用 new 關(guān)鍵字可以獲取到操作的數(shù)據(jù),在insert模式下,new變量中存儲的就是即將插入的數(shù)據(jù)
  • 使用的是 after ,在執(zhí)行完表 emp 的新增之后執(zhí)行這個觸發(fā)器記錄日志。
  • 這個觸發(fā)器什么時候執(zhí)行與兩點有關(guān):
    • 必須操作的是 emp 這個表,也就是on后面聲明的這個表。
    • 必須執(zhí)行的 insert 操作。

創(chuàng)建執(zhí)行 update 的觸發(fā)器:

此時 old 變量中存儲的是被修改前的數(shù)據(jù),new 變量中存儲的是修改之后的數(shù)據(jù)

創(chuàng)建執(zhí)行 delete 的觸發(fā)器:

此時的 old 變量中存儲的即將刪除的數(shù)據(jù)

測試:測試都必須是操作的 emp 表,這樣才會觸發(fā)上邊定義的觸發(fā)器。

2.3 刪除觸發(fā)器

語法結(jié)構(gòu):

drop trigger [schema_name.](數(shù)據(jù)庫名)trigger_name(觸發(fā)器名);

如果沒有指定 schema_name(數(shù)據(jù)庫名),默認(rèn)為當(dāng)前數(shù)據(jù)庫。

2.4 查看觸發(fā)器

可以通過執(zhí)行 show triggers 命令查看觸發(fā)器的狀態(tài)、語法等信息。

語法結(jié)構(gòu):

show triggers;

到此這篇關(guān)于MySQL自定義函數(shù)以及觸發(fā)器的文章就介紹到這了,更多相關(guān)MySQL 觸發(fā)器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 全面分析MySQL?ERROR?1045出現(xiàn)的原因及解決

    全面分析MySQL?ERROR?1045出現(xiàn)的原因及解決

    這篇文章主要介紹了全面分析MySQL?ERROR?1045出現(xiàn)的原因及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • 關(guān)于MySQL查詢語句的優(yōu)化詳解

    關(guān)于MySQL查詢語句的優(yōu)化詳解

    這篇文章主要介紹了MySQL查詢語句的優(yōu)化方法,分別介紹了子查詢優(yōu)化,分頁查詢優(yōu)化以及排序查詢優(yōu)化,對學(xué)習(xí)有一定的幫助,需要的小伙伴可以參考一下
    2023-04-04
  • MySQL創(chuàng)建和刪除表操作命令實例講解

    MySQL創(chuàng)建和刪除表操作命令實例講解

    這篇文章主要介紹了MySQL創(chuàng)建和刪除表操作命令實例講解,本文講解了創(chuàng)建表、創(chuàng)建臨時表、查看已經(jīng)創(chuàng)建的mysql表等內(nèi)容,需要的朋友可以參考下
    2014-12-12
  • mysql行鎖(for update)解決高并發(fā)問題

    mysql行鎖(for update)解決高并發(fā)問題

    這篇文章主要介紹了mysql行鎖(for update)解決高并發(fā)問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • mysql中影響數(shù)據(jù)庫性能的因素講解

    mysql中影響數(shù)據(jù)庫性能的因素講解

    在本篇文章中我們給大家講述了mysql中影響性能的因素以及相關(guān)知識點內(nèi)容,有興趣的朋友參考下。
    2018-09-09
  • mysql數(shù)據(jù)庫備份設(shè)置延時備份方法(mysql主從配置)

    mysql數(shù)據(jù)庫備份設(shè)置延時備份方法(mysql主從配置)

    這篇文章主要介紹了mysql數(shù)據(jù)庫延時備份的方法,也就是mysql主從服務(wù)器備份,可以同步到多個服務(wù)器,最后我們提供了一個備份腳本,大家參考使用吧
    2013-12-12
  • mysql alter table修改表命令整理

    mysql alter table修改表命令整理

    這篇文章主要介紹了mysql alter table修改表命令整理的相關(guān)資料,需要的朋友可以參考下
    2016-10-10
  • MySQL 集群遷移到 Kubernetes操作步驟

    MySQL 集群遷移到 Kubernetes操作步驟

    這篇文章主要為大家介紹了MySQL 集群遷移到 Kubernetes使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • MySQL5.0存儲過程教程

    MySQL5.0存儲過程教程

    Introduction 簡介 MySQL 5.0 新特性教程是為需要了解5.0版本新特性的MySQL老用戶而寫的。簡單的來說是介紹了“存儲過程、觸發(fā)器、視圖、信息架構(gòu)視圖”,在此感謝譯者陳朋奕的努力.
    2008-04-04
  • MySQL Delete 刪數(shù)據(jù)后磁盤空間未釋放的原因

    MySQL Delete 刪數(shù)據(jù)后磁盤空間未釋放的原因

    這篇文章主要介紹了MySQL Delete 刪數(shù)據(jù)后磁盤空間未釋放的原因,幫助大家更好的理解和學(xué)習(xí)使用MySQL,感興趣的朋友可以了解下
    2021-05-05

最新評論