【问题标题】:MariaDB: Before Insert trigger to conditionally abort writing a new recordMariaDB:在插入触发器之前有条件地中止写入新记录
【发布时间】:2021-03-06 22:28:02
【问题描述】:

如果相关书籍已被借出,我正在尝试创建一个触发器以中止为图书馆数据库写入新记录。到目前为止,这是我所拥有的:

CREATE TRIGGER OnlyOneBorrowerAtATime
BEFORE INSERT ON Transaction
FOR EACH ROW
BEGIN
IF (EXISTS ( SELECT * FROM Transaction
       WHERE NEW.bookId = Transaction.bookId AND Transaction.transType = 'Loaned'))
THEN
    SIGNAL SQLSTATE '45000'
       SET MESSAGE_TEXT = 'Book has not been returned';
END IF;
END;

我从 MariaDB 收到以下错误: SQL 错误 (1064):您的 SQL 语法有错误;检查与您的 MariaDB 服务器版本相对应的手册,以了解在第 9 行的 '' 附近使用的正确语法

MariaDB 版本为 10.5.9。

【问题讨论】:

  • 这通常意味着括号不匹配,或缺少分隔符,但我注意到您从未更改过分隔符

标签: mysql sql mariadb


【解决方案1】:

在您的查询中添加DELIMITER,例如

DELIMITER $$
CREATE TRIGGER OnlyOneBorrowerAtATime
BEFORE INSERT ON Transaction
FOR EACH ROW
BEGIN
IF (EXISTS ( SELECT * FROM Transaction
       WHERE NEW.bookId = Transaction.bookId AND Transaction.transType = 'Loaned'))
THEN
    SIGNAL SQLSTATE '45000'
       SET MESSAGE_TEXT = 'Book has not been returned';
END IF;
END$$
DELIMITER ;

【讨论】:

  • 做到了。谢谢!
猜你喜欢
  • 1970-01-01
  • 2013-06-11
  • 2019-07-30
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2014-06-14
  • 2015-07-12
相关资源
最近更新 更多