欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL 在觸發(fā)器里中斷記錄的插入或更新?

 更新時間:2009年07月26日 21:56:46   作者:  
MySQL 不象其它有些數(shù)據(jù)庫可以在觸發(fā)器中拋出異常來中斷當然觸發(fā)器的執(zhí)行以阻止相應的SQL語句的執(zhí)行。在MySQL的目錄版本中還無法直接拋出異常。這樣我們?nèi)绾螌崿F(xiàn)呢?
下面是一種實現(xiàn)的方法。思路就是想辦法在觸發(fā)器中利用一個出錯的語句來中斷代碼的執(zhí)行。
mysql> create table t_control(id int primary key);
Query OK, 0 rows affected (0.11 sec)
mysql> insert into t_control values (1);
Query OK, 1 row affected (0.05 sec)
mysql> create table t_bluerosehero(id int primary key,col int);
Query OK, 0 rows affected (0.11 sec)
mysql> delimiter //
mysql> create trigger tr_t_bluerosehero_bi before insert on t_bluerosehero
-> for each row
-> begin
-> if new.col>30 then
-> insert into t_control values (1);
-> end if;
-> end;
-> //
Query OK, 0 rows affected (0.08 sec)
mysql> delimiter ;
mysql>
mysql> insert into t_bluerosehero values (1,20);
Query OK, 1 row affected (0.25 sec)
mysql> insert into t_bluerosehero values (2,40);
ERROR 1062 (23000): Duplicate entry '1' for key 'PRIMARY'
mysql>
mysql> select * from t_bluerosehero;
+----+------+
| id | col |
+----+------+
| 1 | 20 |
+----+------+
1 row in set (0.00 sec)
mysql>
或者
mysql> delimiter //
mysql> create trigger tr_t_bluerosehero_bi before insert on t_bluerosehero
-> for each row
-> begin
-> declare i int;
-> if new.col>30 then
-> insert into xxxx values (1);
-> end if;
-> end;
-> //
Query OK, 0 rows affected (0.06 sec)
mysql> delimiter ;
mysql> delete from t_bluerosehero;
Query OK, 3 rows affected (0.05 sec)
mysql> insert into t_bluerosehero values (1,20);
Query OK, 1 row affected (0.06 sec)
mysql> insert into t_bluerosehero values (2,40);
ERROR 1146 (42S02): Table 'csdn.xxxx' doesn't exist
mysql>

相關(guān)文章

  • MySQL系列連載之XtraBackup?備份原理解析

    MySQL系列連載之XtraBackup?備份原理解析

    關(guān)于mysql的備份和恢復,比較傳統(tǒng)的是用mysqldump工具,今天本文推薦另一個備份工具innobackupex,重點給大家介紹XtraBackup?備份的相關(guān)知識,感興趣的朋友跟隨小編一起看看吧
    2022-11-11
  • 深入了解MySQL鎖機制及應用場景

    深入了解MySQL鎖機制及應用場景

    MySQL鎖是操作MySQL數(shù)據(jù)庫時常用的一種機制。MySQL鎖可以保證多個用戶在同時執(zhí)行讀寫操作時,能夠互相協(xié)同、避免數(shù)據(jù)出現(xiàn)不一致或者讀寫沖突等問題。本篇文章將詳細介紹MySQL鎖的基本知識和具體應用
    2023-03-03
  • Linux中如何查看mysql版本問題

    Linux中如何查看mysql版本問題

    這篇文章主要介紹了Linux中如何查看mysql版本問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • MySQL數(shù)據(jù)庫的多種連接方式以及實用工具

    MySQL數(shù)據(jù)庫的多種連接方式以及實用工具

    mysql連接操作是客戶端進程與mysql數(shù)據(jù)庫實例進程進行通信,下面這篇文章主要給大家介紹了關(guān)于MySQL數(shù)據(jù)庫的多種連接方式以及實用工具的相關(guān)資料,文中通過圖文介紹的非常詳細,需要的朋友可以參考下
    2023-02-02
  • mysql存儲過程之游標(DECLARE)原理與用法詳解

    mysql存儲過程之游標(DECLARE)原理與用法詳解

    這篇文章主要介紹了mysql存儲過程之游標(DECLARE)原理與用法,結(jié)合實例形式詳細分析了mysql存儲過程游標(DECLARE)的基本功能、原理、使用方法及操作注意事項,需要的朋友可以參考下
    2019-12-12
  • EXCEL數(shù)據(jù)上傳到SQL SERVER中的簡單實現(xiàn)方法

    EXCEL數(shù)據(jù)上傳到SQL SERVER中的簡單實現(xiàn)方法

    以下是對EXCEL數(shù)據(jù)上傳到SQL SERVER中的簡單實現(xiàn)方法進行了詳細的分析介紹,需要的朋友可以過來參考下
    2013-08-08
  • 完美解決mysql啟動后隨即關(guān)閉的問題(ibdata1文件損壞導致)

    完美解決mysql啟動后隨即關(guān)閉的問題(ibdata1文件損壞導致)

    下面小編就為大家?guī)硪黄昝澜鉀Qmysql啟動后隨即關(guān)閉的問題(ibdata1文件損壞導致)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-03-03
  • MySQL DBA教程:Mysql性能優(yōu)化之緩存參數(shù)優(yōu)化

    MySQL DBA教程:Mysql性能優(yōu)化之緩存參數(shù)優(yōu)化

    在平時被問及最多的問題就是關(guān)于 MySQL 數(shù)據(jù)庫性能優(yōu)化方面的問題,所以最近打算寫一個MySQL數(shù)據(jù)庫性能優(yōu)化方面的系列文章,希望對初中級 MySQL DBA 以及其他對 MySQL 性能優(yōu)化感興趣的朋友們有所幫助
    2014-03-03
  • mysql表的內(nèi)連和外連實戰(zhàn)記錄

    mysql表的內(nèi)連和外連實戰(zhàn)記錄

    在開發(fā)中我們的業(yè)務需求有時候是復雜的,多張表聯(lián)合查詢的時候是有多種方式的,面對不同的需求,靈活使用不同的表連接方式,這篇文章主要給大家介紹了關(guān)于mysql表內(nèi)連和外連的相關(guān)資料,需要的朋友可以參考下
    2024-01-01
  • Windows Server2019安裝MySQL5.7.25的方法

    Windows Server2019安裝MySQL5.7.25的方法

    這篇文章主要介紹了Windows Server2019安裝MySQL5.7.25,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-09-09

最新評論