史萊姆論壇

返回   史萊姆論壇 > 專業主討論區 > 論壇程式討論區
忘記密碼?
論壇說明

歡迎您來到『史萊姆論壇』 ^___^

您目前正以訪客的身份瀏覽本論壇,訪客所擁有的權限將受到限制,您可以瀏覽本論壇大部份的版區與文章,但您將無法參與任何討論或是使用私人訊息與其他會員交流。若您希望擁有完整的使用權限,請註冊成為我們的一份子,註冊的程序十分簡單、快速,而且最重要的是--註冊是完全免費的!

請點擊這裡:『註冊成為我們的一份子!』

Google 提供的廣告


發文 回覆
 
主題工具 顯示模式
舊 2007-12-27, 03:28 PM   #1
Admin1
管理員
 
Admin1 的頭像
榮譽勳章
UID - 112827
在線等級: 級別:29 | 在線時長:972小時 | 升級還需:48小時級別:29 | 在線時長:972小時 | 升級還需:48小時級別:29 | 在線時長:972小時 | 升級還需:48小時級別:29 | 在線時長:972小時 | 升級還需:48小時級別:29 | 在線時長:972小時 | 升級還需:48小時級別:29 | 在線時長:972小時 | 升級還需:48小時級別:29 | 在線時長:972小時 | 升級還需:48小時級別:29 | 在線時長:972小時 | 升級還需:48小時級別:29 | 在線時長:972小時 | 升級還需:48小時
註冊日期: 2007-02-18
VIP期限: 0000-00
文章: 3507
精華: 0
現金: 1702 金幣
資產: 10196 金幣
預設 SQL - 06. Triggers

Triggers

使用Triggers的好處:forum$slime&com(tw
  • 可以檢驗即將新增、修改或刪除的row values
  • 可以改變即將新增、修改的row values,因此可做為data filter
  • 可以改變INSERTDELETEUPDATE的預設行為,例如可以將任何temporal column的預設值設定為current time(本來只有TIMESTAMP data type才有這功能)
TRIGGER的類別:forum$slime&com(twhttp://luchinwei.myweb.hinet.net/mysql_certification/19-01.jpg

一個table可以有多個trigger,但同一種類型的trigger只能有一個。

建立TRIGGER的語法:forum$slime&com(tw
CREATE TRIGGER trigger_name
  {BEFORE | AFTER}
  {INSERT | DELETE | UPDATE}
  ON table_name
  FOR EACH ROW
  trigger_statement;

註:其中 "FOR EACH ROW" 是指每個被INSERTDELETEUPDATErow,而不是指目前table中所包含的所有的row

範例:forum$slime&com(tw
DELIMITER //
CREATE TRIGGER slime_bu
 BEFORE UPDATE
 ON slime
 FOR EACH ROW
 BEGIN
  SET @var_name = OLD.name;
 END;
//

註:當TRIGGER執行完後,user varibles(@var_name)即會被設定,可以使用SELECT @var_name來查看其內容。
TRIGGER的限制:forum$slime&com(tw
  • 無法STARTCOMMIT TRANSACTION
  • 無法針對TEMPERARY tableVIEW建立TRIGGER
  • MySQL Server啟用Binary Log時,會有與Stored Routines同樣的限制。
Referring to OLD and NEW Column Valuesforum$slime&com(tw
http://luchinwei.myweb.hinet.net/mysql_certification/19-02.jpg

刪除TRIGGER
  • 使用DROP TRIGGER db_name.trigger_name明確的刪除TRIGGER
  • 刪除TRIGGER所依附的table,則會連帶刪除TRIGGER
  • 刪除TRIGGER所依附的table所屬的database,也會連帶刪除TRIGGER
使用TRIGGER所需要的權限:forum$slime&com(tw
http://luchinwei.myweb.hinet.net/mysql_certification/19-03.jpg




參考資料:www^slime^com^tw
Paul Dubois, Stefan Hinz, Carsten Pedersen(2005), “MySQL 5.0 Certification Study Guide.”
Admin1 目前離線  
送花文章: 8870, 收花文章: 2195 篇, 收花: 5820 次
回覆時引用此帖
有 2 位會員向 Admin1 送花:
cat123799 (2008-05-16),hanklu (2008-01-02)
感謝您發表一篇好文章
發文 回覆



發表規則
不可以發文
不可以回覆主題
不可以上傳附加檔案
不可以編輯您的文章

論壇啟用 BB 語法
論壇啟用 表情符號
論壇啟用 [IMG] 語法
論壇禁用 HTML 語法
Trackbacks are 禁用
Pingbacks are 禁用
Refbacks are 禁用


所有時間均為台北時間。現在的時間是 02:19 AM


Powered by vBulletin® 版本 3.6.8
版權所有 ©2000 - 2024, Jelsoft Enterprises Ltd.


SEO by vBSEO 3.6.1