MySQL觸發(fā)器Trigger加載以及目前局限

  • GreatSQL社區(qū)原創(chuàng)內(nèi)容未經(jīng)授權(quán)不得隨意使用,轉(zhuǎn)載請(qǐng)聯(lián)系小編并注明來(lái)源鞍爱。
  • GreatSQL是MySQL的國(guó)產(chǎn)分支版本举娩,使用上與MySQL一致。
  • 作者: 亮
  • 文章來(lái)源:GreatSQL社區(qū)原創(chuàng)

概念介紹

首先需要知道MySQL中觸發(fā)器特點(diǎn)皿哨,以及表table相關(guān)觸發(fā)器加載方式

  1. MySQL中單個(gè)trigger僅支持單事件觸發(fā)即單個(gè)觸發(fā)器不支持類似insert or update等多事件語(yǔ)法操作,如果需要多事件都能被同一個(gè)表觸發(fā)纽谒,只能分別建立多個(gè)對(duì)應(yīng)trigger证膨。
  2. 觸發(fā)器加載首先需要加載觸發(fā)器分組列表Trigger_chain,后續(xù)再將具體觸發(fā)器添加到Trigger_chain內(nèi)鼓黔。
  3. 表table屬性內(nèi)可包含多個(gè)觸發(fā)器分組列表Trigger_chain央勒,Trigger_chain用于加載不同類別的觸發(fā)器,主要類別有insert澳化、update或delete類型崔步。
  4. 觸發(fā)器分組列表Trigger_chain內(nèi)m_triggers又可加載多個(gè)具體屬于該分組的具體觸發(fā)器。

觸發(fā)器分組列表Trigger_chain加載過(guò)程

1.當(dāng)打開表table時(shí)通過(guò)如下函數(shù)過(guò)程加載觸發(fā)器分組列表Trigger_chain

函數(shù)open_tables->open_and_process_table->handle_table->add_tables_and_routines_for_triggers

2.跟蹤add_tables_and_routines_for_triggers函數(shù)內(nèi)參數(shù)定義

查看TRG_EVENT_MAX定義

enum enum_trigger_event_type {

TRG_EVENT_INSERT = 0,

TRG_EVENT_UPDATE = 1,

TRG_EVENT_DELETE = 2,

TRG_EVENT_MAX

};

查看TRG_ACTION_MAX定義

enum enum_trigger_action_time_type {

TRG_ACTION_BEFORE = 0,

TRG_ACTION_AFTER = 1,

TRG_ACTION_MAX

};

查看函數(shù)get_triggers內(nèi)可知觸發(fā)器加載存儲(chǔ)方式是二維數(shù)組m_trigger_map內(nèi)

/// Triggers grouped by event, action_time.

Trigger_chain *m_trigger_map[TRG_EVENT_MAX] [TRG_ACTION_MAX];
  • 綜合TRG_EVENT_MAX和TRG_ACTION_MAX以及m_trigger_map可以看出目前MySQL觸發(fā)器加載設(shè)計(jì)方式存在一定的弊端肆捕,即TRG_EVENT分組只能按insert刷晋、update盖高、delete區(qū)分慎陵,單次觸發(fā)事件只能觸發(fā)執(zhí)行對(duì)應(yīng)分組內(nèi)的觸發(fā)器,對(duì)于需要擴(kuò)展單觸發(fā)器同時(shí)支持多事件的方式如:insert or update 喻奥、update or delete 等方式將需要較大的改造席纽。

觸發(fā)器分組列表Trigger_chain添加具體觸發(fā)器trigger過(guò)程

1.打開過(guò)的table其觸發(fā)器通過(guò)如下函數(shù)過(guò)程加載

  • 函數(shù)open_tables->open_table_entry_fini->check_n_load

2.具體加載過(guò)程

  • 通過(guò)函數(shù) check_n_load內(nèi)調(diào)用load_triggers函數(shù)從磁盤加載已經(jīng)建好的觸發(fā)器t。

  • 然后調(diào)用create_trigger_chain函數(shù)獲取到前期已經(jīng)加載的觸發(fā)器分組列表Trigger_chain撞蚕。

  • 最后觸發(fā)器分組列表Trigger_chain調(diào)用add_trigger添加具體觸發(fā)器t至分組列表內(nèi)润梯。

  • 當(dāng)目標(biāo)表table有insert、update或delete操作時(shí),即會(huì)觸發(fā)執(zhí)行對(duì)應(yīng)分組列表Trigger_chain內(nèi)相應(yīng)分組的觸發(fā)器纺铭。

說(shuō)明:MySQL在新增和刪除觸發(fā)器的操作時(shí)都會(huì)關(guān)閉當(dāng)前已經(jīng)打開的table句柄寇钉,在下次打開table時(shí)會(huì)重新load相應(yīng)的trigger。

Enjoy GreatSQL :)

關(guān)于 GreatSQL

GreatSQL是由萬(wàn)里數(shù)據(jù)庫(kù)維護(hù)的MySQL分支舶赔,專注于提升MGR可靠性及性能扫倡,支持InnoDB并行查詢特性,是適用于金融級(jí)應(yīng)用的MySQL分支版本竟纳。

相關(guān)鏈接: GreatSQL社區(qū) Gitee GitHub Bilibili

GreatSQL社區(qū):

社區(qū)有獎(jiǎng)建議反饋: https://greatsql.cn/thread-54-1-1.html

社區(qū)博客有獎(jiǎng)?wù)鞲逶斍椋?/strong> https://greatsql.cn/thread-100-1-1.html

社區(qū)2022年度勛章獲獎(jiǎng)名單: https://greatsql.cn/thread-184-1-1.html

(對(duì)文章有疑問(wèn)或者有獨(dú)到見(jiàn)解都可以去社區(qū)官網(wǎng)提出或分享哦~)

技術(shù)交流:

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末撵溃,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子锥累,更是在濱河造成了極大的恐慌缘挑,老刑警劉巖,帶你破解...
    沈念sama閱讀 210,978評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件桶略,死亡現(xiàn)場(chǎng)離奇詭異语淘,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)际歼,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,954評(píng)論 2 384
  • 文/潘曉璐 我一進(jìn)店門亏娜,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人蹬挺,你說(shuō)我怎么就攤上這事维贺。” “怎么了巴帮?”我有些...
    開封第一講書人閱讀 156,623評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵溯泣,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我榕茧,道長(zhǎng)垃沦,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,324評(píng)論 1 282
  • 正文 為了忘掉前任用押,我火速辦了婚禮肢簿,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘蜻拨。我一直安慰自己池充,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,390評(píng)論 5 384
  • 文/花漫 我一把揭開白布缎讼。 她就那樣靜靜地躺著收夸,像睡著了一般。 火紅的嫁衣襯著肌膚如雪血崭。 梳的紋絲不亂的頭發(fā)上卧惜,一...
    開封第一講書人閱讀 49,741評(píng)論 1 289
  • 那天厘灼,我揣著相機(jī)與錄音,去河邊找鬼咽瓷。 笑死设凹,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的茅姜。 我是一名探鬼主播围来,決...
    沈念sama閱讀 38,892評(píng)論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼匈睁!你這毒婦竟也來(lái)了监透?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,655評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤航唆,失蹤者是張志新(化名)和其女友劉穎胀蛮,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體糯钙,經(jīng)...
    沈念sama閱讀 44,104評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡粪狼,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,451評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了任岸。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片再榄。...
    茶點(diǎn)故事閱讀 38,569評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖享潜,靈堂內(nèi)的尸體忽然破棺而出困鸥,到底是詐尸還是另有隱情,我是刑警寧澤剑按,帶...
    沈念sama閱讀 34,254評(píng)論 4 328
  • 正文 年R本政府宣布疾就,位于F島的核電站,受9級(jí)特大地震影響艺蝴,放射性物質(zhì)發(fā)生泄漏猬腰。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,834評(píng)論 3 312
  • 文/蒙蒙 一猜敢、第九天 我趴在偏房一處隱蔽的房頂上張望姑荷。 院中可真熱鬧,春花似錦缩擂、人聲如沸鼠冕。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,725評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)供鸠。三九已至,卻和暖如春陨闹,著一層夾襖步出監(jiān)牢的瞬間楞捂,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,950評(píng)論 1 264
  • 我被黑心中介騙來(lái)泰國(guó)打工趋厉, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留寨闹,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,260評(píng)論 2 360
  • 正文 我出身青樓君账,卻偏偏與公主長(zhǎng)得像繁堡,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子乡数,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,446評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容