mysql 检查日期约束(触发器)

标签 mysql mariadb

很抱歉再次打扰,我对 MySql Maria DB 完全陌生(可能也在触发器上),并希望添加检查功能以确保在此表中没有插入过去的日期。 我相信Mysql唯一的方法就是创建一个触发器。 我尝试创建一个,但仍然遇到问题。有人可以告诉我我在这里做错了什么吗(也许我需要一杯 espresso ):

CREATE TRIGGER check_date BEFORE INSERT on Event
  FOR EACH ROW 
  BEGIN 
  if new.date <= now() then
  SIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = 'Event cannot start in the past     event cannot start now. Choose an ulterior date'
end
end if;

请注意我正在终端上。每当系统看到分号时,它就会结束我的查询。因此我不能有 2 个分号。

感谢您的帮助。 我希望我足够清楚......

最佳答案

您需要在查询之前更改分隔符:

delimiter //

CREATE TRIGGER check_date BEFORE INSERT on Event
FOR EACH ROW
BEGIN
  IF new.date <= now() THEN
    SIGNAL SQLSTATE '45000' 
    SET MESSAGE_TEXT = 'Event cannot start in the past     event cannot start now. Choose an ulterior date';
  END IF;
END;//

delimiter ;

此外,在END为事件(触发器)执行的整个代码块之前结束IF语句

关于mysql 检查日期约束(触发器),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40118653/

相关文章:

javascript - Express.js 和 koa2.js 在处理异步函数时的区别?

MySQL 检索行并将它们转换为列

php - 按时间顺序从不同表中获取帖子

javascript - 如何使用 Sequelize 将值 'null' 插入 MariaDB?

mysql - #1054 - 从 Mysql 导出到 MariaDB 后 order 子句中的未知列

mysql - 选择某些标记的帖子及其作者

php - 如何使用 QueryBuilder 计算 CURRENT_DATE() 与上个月之间的天数差异?

mysql - 在 MariaDB/MySQL 中何时不使用 <=> 而不是 =?

mariadb - 在 MariaDB 上禁用严格模式

mysql - Memory_used 是否以字节为单位?