主頁 > 資料庫 > MySQL觸發器的詳細教學與實戰分析

MySQL觸發器的詳細教學與實戰分析

2020-09-14 02:08:42 資料庫

所有知識體系文章,GitHub已收錄,歡迎老板們前來Star!

GitHub地址: https://github.com/Ziphtracks/JavaLearningmanual

MySQL觸發器


一、什么是觸發器

觸發器(trigger)是MySQL提供給程式員和資料分析員來保證資料完整性的一種方法,它是與表事件相關的特殊的存盤程序,它的執行不是由程式呼叫,也不是手工啟動,而是由事件來觸發,比如當對一個表進行操作(insert,delete, update)時就會激活它執行,簡單理解為:你執行一條sql陳述句,這條sql陳述句的執行會自動去觸發執行其他的sql陳述句,

二、觸發器的作用

  • 可在寫入資料表前,強制檢驗或轉換資料,
  • 觸發器發生錯誤時,異動的結果會被撤銷,
  • 部分資料庫管理系統可以針對資料定義語言(DDL)使用觸發器,稱為DDL觸發器,
  • 可依照特定的情況,替換異動的指令 (INSTEAD OF),

三、觸發器創建的四要素

  • 監視地點(table)
  • 監視事件(insert、update、delete)
  • 觸發時間(after、before)
  • 觸發事件(insert、update、delete)

四、觸發器的使用語法

語法:

before/after: 觸發器是在增刪改之前執行,還是之后執行

delete/insert/update: 觸發器由哪些行為觸發(增、刪、改)

on 表名: 觸發器監視哪張表的(增、刪、改)操作

觸發SQL代碼塊: 執行觸發器包含的SQL陳述句

1CREATE TRIGGER 觸發器名
2BEFORE|AFTER DELETE|INSERT|UPDATE
3ON 表名 FOR EACH ROW
4BEGIN
5觸發SQL代碼塊;
6END;

注意: 觸發器也是存盤程序程式的一種,而觸發器內部的執行SQL陳述句是可以多行操作的,所以在MySQL的存盤程序程式中,要定義結束符,

如果MySQL存盤程序不了解的小伙伴,可以參考此文面向MySQL存盤程序編程,文章中詳細講解了MySQL存盤程序的優勢和語法等等,相信你會在其中得以識訓,

1# 設定MySQL執行結束標志,默認為;
2delimiter //

五、觸發器的基本使用

5.1 基本使用步驟

首先,我先展示一下創建的兩張表,因為創建的表很簡單,這里我沒有提供庫表操作的SQL命令,

tb_class

image-20200611205404311
image-20200611205404311

employee

image-20200611205435284
image-20200611205435284

其次,創建了一個含有update操作的存盤程序

1delimiter //
2create procedure update_emp(in i intin p int)
3begin
4    update employee set phone = p where id = i;
5end //

再創建一個觸發器

分析: 觸發器名稱為t1,觸發時間為after,監視動作為update,監視表為employee表,匯總一起解釋這個觸發器就是:創建一個觸發器名稱為t1的觸發器,觸發器監視employee表執行update(更新)操作后,就開始執行觸發器內部SQL陳述句update tb_class set num = num + 1 where id = 1;

簡單來說就是一個監視一個表的增、刪、改操作并設定操作前后時間,在設定時間的范圍內對另外一個表進行其他操作,

如果你學到這里還是一知半解,后面我會講解一個訂單與庫存的資料關系,到那時候你就會明白了!

 1delimiter //
2# 創建觸發器,觸發器名稱為t1
3create trigger t1
4    # 觸發器執行在update操作之后
5    after update
6    # 監視employee表
7    on employee
8    for each row
9begin
10    # 觸發執行的SQL陳述句
11    update tb_class set num = num + 1 where id = 1;
12end //

最后呼叫函式,并查看、分析結果

1call update_emp(2110);

觸發器在此場景的作用分析

當employee表發生update操作時,觸發器就對tb_class表中的num值做修改,

執行結果發現,我們在使用函式將employee表中id為2員工的phone修改為110后,觸發器監視到employee表中發生了update更新操作,就執行了內部SQL陳述句,也就是將tb_class表中id為1的num值自增1,

image-20200611213411229
image-20200611213411229
image-20200611213432459
image-20200611213432459

5.2 查看和洗掉已有的觸發器

查看已有觸發器: show triggers

洗掉已有觸發器: drop trigger 觸發器名稱

5.3 for each row

這里擴展,在oracle觸發器中,觸發器分為行觸發器和陳述句觸發器,也就是說,假設你監視一個修改操作,它修改了1000行代碼,在Oracle中觸發器會觸發1000次,

在oracle中,for each row如果不寫,無論update陳述句一次影響了多少行,都只執行一次觸發事件,

而MySQL中,不支持陳述句級觸發器,所以在MySQL中并不需要在意,

六、訂單與庫存關系場景

訂單與庫存的關系: 用戶下訂單,意味著創建該商品訂單,該商品訂單中的商品數量為1,庫存中的該商品數量-1,往往訂單表和庫存表中的數量是同時操作的,所以我們這里可以用觸發器,

觸發器應用: 關于訂單表,下訂單肯定是涉及到insert插入資料數量的操作,我們可以創建一個監視訂單表insert操作后執行庫存表數量-1的觸發器來完成訂單與庫存表的同時修改,

創建表,并在表中添加幾條資料:

 1create table goods(
2  gid int,
3  name varchar(20),
4  num smallint
5);
6create table ord(
7  oid int,
8  gid int,
9  much smallint
10);
11insert into goods values(1,'cat',40);
12insert into goods values(2,'dog',63);
13insert into goods values(3,'pig',87);

創建觸發器

1create trigger t1 
2after
3insert
4on ord
5for each row
6begin
7 update goods set num = num - 1 where gid = 1;
8end$

該觸發器意為,用戶不管下什么訂單,都會把商品編號為1的商品的庫存減去1,

七、觸發器中參考行變數

7.1 old和new物件語法

  • 在觸發目標上執行insert操作后會有一個新行,如果在觸發事件中需要用到這個新行的變數,可以用new關鍵字表示
  • 在觸發目標上執行delete操作后會有一個舊行,如果在觸發事件中需要用到這個舊行的變數,可以用old關鍵字表示
  • 在觸發目標上執行update操作后原紀錄是舊行,新記錄是新行,可以使用new和old關鍵字來分別操作
觸發陳述句 old new
insert 所有欄位都為空 將要插入的資料
update 更新以前該行的值 更新后的值
delete 洗掉以前該行的值 所有欄位都為空

7.2 old和new物件應用

關于old和new物件的應用,我在這里沒有展開演示,只是將第八章的綜合案例結合了old和new物件實作,綜合案例中詳細講解了MySQL觸發器的使用!

八、綜合案例

8.1 創建表、插入表資料

tb_class為幼兒園班級表,其中cid為唯一主鍵,cname為大、中、小班班級標準,stuNo為班級標準內的學生個數,插入大、中、小班標準,初始化兩名學生在大班,

tb_stu為幼兒園學生表,其中sid為唯一主鍵,sname為學生性名,cno為所在班級標準的外鍵,插入兩條資料并初始化這兩名學生在大班,因為我們在班級表中初始化了兩名學生在大班嘛,所以要做此操作,

 1create table tb_class
2(
3    cid   int auto_increment
4        primary key,
5    cname varchar(32not null,
6    stuNo int         not null
7);
8
9INSERT INTO temp.tb_class (cname, stuNo) VALUES ('大班'2)
10INSERT INTO temp.tb_class (cname, stuNo) VALUES ('中班'0)
11INSERT INTO temp.tb_class (cname, stuNo) VALUES ('小班'0)
12
13create table tb_stu
14(
15    sid   int auto_increment
16        primary key,
17    sname varchar(32not null,
18    cno   int         not null
19);
20
21INSERT INTO temp.tb_stu (sname, cno) VALUES ('Ziph'1)
22INSERT INTO temp.tb_stu (sname, cno) VALUES ('Join'1)

8.2 添加學生案例

在此表結構中,如果一位新同學來到學校學習,意味著某一個班級中會多出一名學生,假設Marry同學去小班學習,其表結構的變化為:tb_stu表中添加一條Marry的記錄(注:cno = 3),tb_class表中小班記錄的stuNo = 0修改為stuNo = 1

先創建一個添加學生的存盤程序

1# 添加學生函式
2delimiter //
3# 創建存盤程序,傳入學生性名和班級引數
4create procedure add_stu(in in_sname varchar(32), in in_cno int)
5begin
6    # 插入記錄
7    insert into tb_stu (sname, cno) values (in_sname, in_cno);
8end //

創建觸發器

注意: 在更新學生數量SQL陳述句中,有一段cid = new.cno的SQL陳述句,這里我解釋一下,new代表產生的新物件,將cid主鍵與添加Marry記錄后產生的新紀錄物件的cno外鍵關聯,(因為insert后產生的是新紀錄物件嘛,所以用new)

 1# 觸發器
2# 創建名稱為t_add_stu的觸發器
3create trigger t_add_stu
4    # 設定在insert操作之后觸發
5    after
6        insert
7    # 監視tb_stu的insert操作
8    on tb_stu
9    for each row
10begin
11    # 更新學生數量(cid為tb_class表中主鍵,cno為tb_stu表中外鍵)
12    update tb_class set stuNo = stuNo + 1 where cid = new.cno;
13end //

宣告回結束符

1delimiter ;

插入Marry學生記錄到資料庫表中

1call add_stu('Marry'3);

執行結果就是當插入Marry學生記錄的同時也修改了班級表中的小班學生數量,

8.3 洗掉學生案例

洗掉學生與添加學生十分相似,洗掉學生相當于是添加學生的逆程序,如果以為學生退學了或者讀完了幼兒園離開學校了,就意味著班級中少了一位學生,假設Join同學讀完了大班結束了幼兒園階段的學習將要幼兒園去上小學,其表結構變化為:tb_stu洗掉Join這條記錄(注:sid = 2),tb_class將修改Join所在大班班級級別的stuNo,即stuNo = stuNo - 1

先創建一個洗掉學生的存盤程序

1# 洗掉學生
2delimiter //
3create procedure delete_stu(in in_sid int)
4begin
5    delete from tb_stu where sid = in_sid;
6end //

創建觸發器

注意: 在更新學生數量的時候,書寫了此段SQL陳述句cid = OLD.cno,該陳述句使用old物件,意為Join學生的記錄沒有了,但是使用觸發器同步修改tb_class表中的大班學生數量還需要用到關聯Join學生所在記錄的外鍵cno,使用old來句點出來的cno就是洗掉之前Join那一條學生記錄的cno,(如果我們用new,該記錄還存在嗎?該記錄的cno還存在嗎?答案是都不存在了!)

 1# 觸發器
2# 創建觸發器名稱為t_delete_stu的觸發器
3create trigger t_delete_stu
4    # 設定在delete操作之后觸發
5    after
6        delete
7    # 監視tb_stu表的delete操作
8    on tb_stu
9    for each row
10begin
11    # 更新學生數量(cid為tb_class表中主鍵,cno為tb_stu表中外鍵)
12    update tb_class set stuNo = stuNo - 1 where cid = OLD.cno;
13end //

宣告回結束符

1delimiter ;

洗掉Jion學生記錄

1call delete_stu(2);

執行結果為Join記錄在資料庫的表中消失了,而大班的學生數量也減掉了1,

8.4 洗掉班級案例

因為我已經詳細講解了添加學生與洗掉學生,所以洗掉班級我就不再作過多的贅述了,那就直接說核心內容吧,洗掉一個班級級別比如:洗掉小班之前要把小班內的所有學生也被洗掉了,因為兩個表是主外鍵關聯的,如果只洗掉了小班,而沒有洗掉小班內的所有學生,那么原小班內的所有學生現在屬于哪個班級呢,就不知道了吧!所以要在洗掉小班之前洗掉小班內的所有學生,

 1# 創建洗掉班級的存盤程序
2delimiter //
3create procedure delete_class(in in_cid int)
4begin
5    delete from tb_class where cid = in_cid;
6end //
7
8# 創建觸發器名稱為t_delete_class的觸發器
9create trigger t_delete_class
10    # 作用在delete操作之前
11    before
12        delete
13    # 監視tb_class表中的delete操作
14    on tb_class
15    for each row
16begin
17    # 同時洗掉所有該原班級cid的所有學生
18    delete from tb_stu where cno = OLD.cid;
19end //
20
21# 將結束符宣告為;
22delimiter ;
23
24# 洗掉小班班級別
25call delete_class(3);

執行結果為既洗掉了小班,又洗掉小班內的所有學生,

8.5 觸發器沖突問題

觸發器沖突問題其實就是關聯問題,為什么這么說呢?就說以下剛才這三個案例中出現的觸發器沖突問題,

如果我們在寫觸發器的時候,將添加學生、洗掉學生和洗掉班級的觸發器都寫在一個查詢模板中,你會發現當你在洗掉班級的時候,會報錯,顯示如下資訊:

image-20200612004546204
image-20200612004546204

這是為什么呢?

仔細想想,我們將在案例中有兩個是同一個表中的洗掉觸發器,洗掉班級的觸發器中定義的是洗掉班級時觸發洗掉學生,而洗掉學生的觸發器中定義的是班級人數減一,你發現了沒,觸發器被連著觸發了,如下變化:

image-20200612005312835
image-20200612005312835

我們通過洗掉班級案例了解了,洗掉班級之前需要把班級內所有學生洗掉掉,正因為如此,我們在洗掉班級之前已經把所有學生都洗掉了,導致在洗掉學生的時候觸發了班級人數減一的觸發器,該觸發器在執行程序中修改了已經被洗掉班級的學生人數,這問題就出在這里了,班級已經洗掉了,怎么修改一個本就沒有的班級內的人數呢?對吧!

解決觸發器沖突

為解決這個場景的觸發器沖突問題,我們只能取舍一個觸發器,于是,就通過命令洗掉了洗掉學生案例中使用的那個觸發器,洗掉后洗掉班級就可以成功執行觸發了!

1drop trigger t_delete_stu;

注意: 由于存在觸發器沖突問題,我們在實際開發中需要認真考量定義觸發器!

九、觸發器性能和使用分析(必讀)

各大論壇等等,相信在大家的文章中都不推薦使用觸發器,而是推薦使用存盤程序程式,這是為什么呢?

首先,存盤程序程式分為存盤程序、儲存程序函式和觸發器,也就是說這三種都是存盤程序的使用都是存盤程序的表現形式,

如果場景在資料量和并發量都很大的情況下,使用觸發器、存盤程序再加上幾個事務等等,很容易出現死鎖,而且在使用觸發器的時候,也會出現沖突,出現問題時,我們需要追溯的代碼就需要從一個觸發器到另一個觸發器……從而影響開發效率,從性能上看,觸發器也是存盤程序程式的一種,它也并沒有展現出多少性能上的優勢,由于觸發器寫起來比較隱蔽,容易被開發人員忽略,而且隱式呼叫觸發器不易于排除依賴,對后期維護不是很友好!

所以在開發中,觸發器是很少用到的,那為什么我還花時間大篇幅的講解MySQL觸發器呢?原因很簡單,是因為需要擴展自己的知識儲備,開發中的使用問題和是否被大家摒棄,不是你拒絕學習知識的理由,之所以存在就有它存在的道理,我們在學習的道路中不斷擴充自己的知識儲備即可,

假如有一天你的同事聊起觸發器,你也能和他們聊聊你對觸發器的見解是哈?如果你根據從未了解過此知識呢?那性質就不一樣了,相信大家都懂吧!

轉載請註明出處,本文鏈接:https://www.uj5u.com/shujuku/29424.html

標籤:MySQL

上一篇:mysql查詢優化

下一篇:SQL--SQL詳解(DDL,DML,DQL,DCL)

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • GPU虛擬機創建時間深度優化

    **?桔妹導讀:**GPU虛擬機實體創建速度慢是公有云面臨的普遍問題,由于通常情況下創建虛擬機屬于低頻操作而未引起業界的重視,實際生產中還是存在對GPU實體創建時間有苛刻要求的業務場景。本文將介紹滴滴云在解決該問題時的思路、方法、并展示最終的優化成果。 從公有云服務商那里購買過虛擬主機的資深用戶,一 ......

    uj5u.com 2020-09-10 06:09:13 more
  • 可編程網卡芯片在滴滴云網路的應用實踐

    **?桔妹導讀:**隨著云規模不斷擴大以及業務層面對延遲、帶寬的要求越來越高,采用DPDK 加速網路報文處理的方式在橫向縱向擴展都出現了局限性。可編程芯片成為業界熱點。本文主要講述了可編程網卡芯片在滴滴云網路中的應用實踐,遇到的問題、帶來的收益以及開源社區貢獻。 #1. 資料中心面臨的問題 隨著滴滴 ......

    uj5u.com 2020-09-10 06:10:21 more
  • 滴滴資料通道服務演進之路

    **?桔妹導讀:**滴滴資料通道引擎承載著全公司的資料同步,為下游實時和離線場景提供了必不可少的源資料。隨著任務量的不斷增加,資料通道的整體架構也隨之發生改變。本文介紹了滴滴資料通道的發展歷程,遇到的問題以及今后的規劃。 #1. 背景 資料,對于任何一家互聯網公司來說都是非常重要的資產,公司的大資料 ......

    uj5u.com 2020-09-10 06:11:05 more
  • 滴滴AI Labs斬獲國際機器翻譯大賽中譯英方向世界第三

    **桔妹導讀:**深耕人工智能領域,致力于探索AI讓出行更美好的滴滴AI Labs再次斬獲國際大獎,這次獲獎的專案是什么呢?一起來看看詳細報道吧! 近日,由國際計算語言學協會ACL(The Association for Computational Linguistics)舉辦的世界最具影響力的機器 ......

    uj5u.com 2020-09-10 06:11:29 more
  • MPP (Massively Parallel Processing)大規模并行處理

    1、什么是mpp? MPP (Massively Parallel Processing),即大規模并行處理,在資料庫非共享集群中,每個節點都有獨立的磁盤存盤系統和記憶體系統,業務資料根據資料庫模型和應用特點劃分到各個節點上,每臺資料節點通過專用網路或者商業通用網路互相連接,彼此協同計算,作為整體提供 ......

    uj5u.com 2020-09-10 06:11:41 more
  • 滴滴資料倉庫指標體系建設實踐

    **桔妹導讀:**指標體系是什么?如何使用OSM模型和AARRR模型搭建指標體系?如何統一流程、規范化、工具化管理指標體系?本文會對建設的方法論結合滴滴資料指標體系建設實踐進行解答分析。 #1. 什么是指標體系 ##1.1 指標體系定義 指標體系是將零散單點的具有相互聯系的指標,系統化的組織起來,通 ......

    uj5u.com 2020-09-10 06:12:52 more
  • 單表千萬行資料庫 LIKE 搜索優化手記

    我們經常在資料庫中使用 LIKE 運算子來完成對資料的模糊搜索,LIKE 運算子用于在 WHERE 子句中搜索列中的指定模式。 如果需要查找客戶表中所有姓氏是“張”的資料,可以使用下面的 SQL 陳述句: SELECT * FROM Customer WHERE Name LIKE '張%' 如果需要 ......

    uj5u.com 2020-09-10 06:13:25 more
  • 滴滴Ceph分布式存盤系統優化之鎖優化

    **桔妹導讀:**Ceph是國際知名的開源分布式存盤系統,在工業界和學術界都有著重要的影響。Ceph的架構和演算法設計發表在國際系統領域頂級會議OSDI、SOSP、SC等上。Ceph社區得到Red Hat、SUSE、Intel等大公司的大力支持。Ceph是國際云計算領域應用最廣泛的開源分布式存盤系統, ......

    uj5u.com 2020-09-10 06:14:51 more
  • es~通過ElasticsearchTemplate進行聚合~嵌套聚合

    之前寫過《es~通過ElasticsearchTemplate進行聚合操作》的文章,這一次主要寫一個嵌套的聚合,例如先對sex集合,再對desc聚合,最后再對age求和,共三層嵌套。 Aggregations的部分特性類似于SQL語言中的group by,avg,sum等函式,Aggregation ......

    uj5u.com 2020-09-10 06:14:59 more
  • 爬蟲日志監控 -- Elastc Stack(ELK)部署

    傻瓜式部署,只需替換IP與用戶 導讀: 現ELK四大組件分別為:Elasticsearch(核心)、logstash(處理)、filebeat(采集)、kibana(可視化) 下載均在https://www.elastic.co/cn/downloads/下tar包,各組件版本最好一致,配合fdm會 ......

    uj5u.com 2020-09-10 06:15:05 more
最新发布
  • day02-2-商鋪查詢快取

    功能02-商鋪查詢快取 3.商鋪詳情快取查詢 3.1什么是快取? 快取就是資料交換的緩沖區(稱作Cache),是存盤資料的臨時地方,一般讀寫性能較高。 快取的作用: 降低后端負載 提高讀寫效率,降低回應時間 快取的成本: 資料一致性成本 代碼維護成本 運維成本 3.2需求說明 如下,當我們點擊商店詳 ......

    uj5u.com 2023-04-20 08:33:24 more
  • MySQL中binlog備份腳本分享

    關于MySQL的二進制日志(binlog),我們都知道二進制日志(binlog)非常重要,尤其當你需要point to point災難恢復的時侯,所以我們要對其進行備份。關于二進制日志(binlog)的備份,可以基于flush logs方式先切換binlog,然后拷貝&壓縮到到遠程服務器或本地服務器 ......

    uj5u.com 2023-04-20 08:28:06 more
  • day02-短信登錄

    功能實作02 2.功能01-短信登錄 2.1基于Session實作登錄 2.1.1思路分析 2.1.2代碼實作 2.1.2.1發送短信驗證碼 發送短信驗證碼: 發送驗證碼的介面為:http://127.0.0.1:8080/api/user/code?phone=xxxxx<手機號> 請求方式:PO ......

    uj5u.com 2023-04-20 08:27:27 more
  • 快取與資料庫雙寫一致性幾種策略分析

    本文將對幾種快取與資料庫保證資料一致性的使用方式進行分析。為保證高并發性能,以下分析場景不考慮執行的原子性及加鎖等強一致性要求的場景,僅追求最終一致性。 ......

    uj5u.com 2023-04-20 08:26:48 more
  • sql陳述句優化

    問題查找及措施 問題查找 需要找到具體的代碼,對其進行一對一優化,而非一直把關注點放在服務器和sql平臺 降低簡化每個事務中處理的問題,盡量不要讓一個事務拖太長的時間 例如檔案上傳時,應將檔案上傳這一步放在事務外面 微軟建議 4.啟動sql定時執行計劃 怎么啟動sqlserver代理服務-百度經驗 ......

    uj5u.com 2023-04-20 08:26:35 more
  • 云時代,MySQL到ClickHouse資料同步產品對比推薦

    ClickHouse 在執行分析查詢時的速度優勢很好的彌補了MySQL的不足,但是對于很多開發者和DBA來說,如何將MySQL穩定、高效、簡單的同步到 ClickHouse 卻很困難。本文對比了 NineData、MaterializeMySQL(ClickHouse自帶)、Bifrost 三款產品... ......

    uj5u.com 2023-04-20 08:26:29 more
  • sql陳述句優化

    問題查找及措施 問題查找 需要找到具體的代碼,對其進行一對一優化,而非一直把關注點放在服務器和sql平臺 降低簡化每個事務中處理的問題,盡量不要讓一個事務拖太長的時間 例如檔案上傳時,應將檔案上傳這一步放在事務外面 微軟建議 4.啟動sql定時執行計劃 怎么啟動sqlserver代理服務-百度經驗 ......

    uj5u.com 2023-04-20 08:25:13 more
  • Redis 報”OutOfDirectMemoryError“(堆外記憶體溢位)

    Redis 報錯“OutOfDirectMemoryError(堆外記憶體溢位) ”問題如下: 一、報錯資訊: 使用 Redis 的業務介面 ,產生 OutOfDirectMemoryError(堆外記憶體溢位),如圖: 格式化后的報錯資訊: { "timestamp": "2023-04-17 22: ......

    uj5u.com 2023-04-20 08:24:54 more
  • day02-2-商鋪查詢快取

    功能02-商鋪查詢快取 3.商鋪詳情快取查詢 3.1什么是快取? 快取就是資料交換的緩沖區(稱作Cache),是存盤資料的臨時地方,一般讀寫性能較高。 快取的作用: 降低后端負載 提高讀寫效率,降低回應時間 快取的成本: 資料一致性成本 代碼維護成本 運維成本 3.2需求說明 如下,當我們點擊商店詳 ......

    uj5u.com 2023-04-20 08:24:03 more
  • day02-短信登錄

    功能實作02 2.功能01-短信登錄 2.1基于Session實作登錄 2.1.1思路分析 2.1.2代碼實作 2.1.2.1發送短信驗證碼 發送短信驗證碼: 發送驗證碼的介面為:http://127.0.0.1:8080/api/user/code?phone=xxxxx<手機號> 請求方式:PO ......

    uj5u.com 2023-04-20 08:23:11 more