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

mysql之觸發(fā)器使用

 更新時(shí)間:2017年09月12日 08:09:55   作者:WalkerShen  
這篇文章主要介紹了mysql之觸發(fā)器使用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

觸發(fā)器

什么是觸發(fā)器?觸發(fā)器的使用場(chǎng)景有哪些?

觸發(fā)器是用戶定義在關(guān)系表上的一類由事件驅(qū)動(dòng)的特殊的存儲(chǔ)過程。

觸發(fā)器是指一段代碼,當(dāng)觸發(fā)某個(gè)事件時(shí),自動(dòng)執(zhí)行這些代碼。

使用場(chǎng)景

  • 可以通過數(shù)據(jù)庫(kù)中的相關(guān)表實(shí)現(xiàn)級(jí)聯(lián)更改。
  • 實(shí)時(shí)監(jiān)控某張表中的某個(gè)字段的更改而需要做出相應(yīng)的處理。
  • 例如可以生成某些業(yè)務(wù)的編號(hào)。
  • 注意不要濫用,否則會(huì)造成數(shù)據(jù)庫(kù)及應(yīng)用程序的維護(hù)困難。
  • 大家需要牢記以上基礎(chǔ)知識(shí)點(diǎn),重點(diǎn)是理解數(shù)據(jù)類型CHAR和VARCHAR的差異,表存儲(chǔ)引擎InnoDB和MyISAM的區(qū)別。

MySQL中都有哪些觸發(fā)器?

在MySQL數(shù)據(jù)庫(kù)中有如下六種觸發(fā)器:

  • Before Insert
  • After Insert
  • Before Update
  • After Update
  • Before Delete
  • After Delete

觸發(fā)器的使用

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

DELIMITER $
CREATE TRIGGER 觸發(fā)器名稱
BEFORE|AFTER  INSERT|UPDATE|DELETE
ON 表名
[FOR EACH ROW]  -- 行級(jí)觸發(fā)器
BEGIN
  觸發(fā)器要執(zhí)行的功能;
END$
DELIMITER ;

  • BEFORE|AFTER 表示是在操作之前還操作之后觸發(fā)
  • INSERT|UPDATE|DELETE 是添加、修改、刪除的意思
  • ON 表名 表示是對(duì)哪一張表進(jìn)行添加、修改或者刪除的時(shí)候觸發(fā)我們要的操作

使用案例

這里是創(chuàng)建一個(gè)學(xué)生表,和一個(gè)操作記錄表

當(dāng)插入學(xué)生數(shù)據(jù)的時(shí)候,日志表就會(huì)啟動(dòng)觸發(fā)器進(jìn)行插入

1、創(chuàng)建表

CREATE TABLE `student` (
  `id` varchar(64) NOT NULL,
  `name` varchar(255) DEFAULT NULL,
  `gender` tinyint(1) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;


CREATE TABLE `student_log` (
  `id` varchar(64) NOT NULL COMMENT '日志id',
  `opt_type` varchar(1) DEFAULT NULL COMMENT '操作類型 i:插入 u:修改 d:刪除',
  `opt_time` datetime DEFAULT NULL COMMENT '操作時(shí)間',
  `opt_id` varchar(64) DEFAULT NULL COMMENT '操作id',
  `data` varchar(255) DEFAULT NULL COMMENT '數(shù)據(jù)',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

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

create trigger student_log_insert
after insert  # 插入之后處理
on student  
for each row # 代表著每行都遵循這個(gè)規(guī)則

# 這里的new代表的是student這個(gè)表的新數(shù)據(jù)
begin 
insert into student_log values(
new.id+"111",
'i',
NOW(),
new.id,
concat('{id=',new.id,';','name=',new.name,';','gender=',new.gender,';}')
);
end 

3、查看觸發(fā)器是否成功

# 查看觸發(fā)器
show triggers


# 如果觸發(fā)器不符合自己的要求,可以刪除觸發(fā)器
DROP TRIGGER student_log_insert

image.png

4、測(cè)試

insert into student values("112154","i am walker",1);
insert into student values("11111","this is raina",1);

執(zhí)行結(jié)果之后,查看表,數(shù)據(jù)就出來了

image.png

image.png

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論