您的SQL语句没有语法错误。 MySQL服务器中没有特定的“设置”来控制此行为,但是有一些设置可以影响特定的INSERT语句是否成功,例如,允许无效日期的设置(即不存在的日期)例如6月31日),以及允许存储零日期('0000-00-00')的设置。 (这种行为在不同版本中发生了变化,其中“旧”(例如V3.23)默认为允许无效日期,而“较新”(例如v5.1)默认为禁止无效日期。)
如果为绑定参数提供的值有效,那么您观察到的行为最可能的解释是存在(或将会)违反的CONSTRAINT。
这可能是主键约束,唯一键约束,外键约束,NOT NULL约束,或者它甚至可能是抛出异常的触发器。
例如,列干预可以定义为NOT NULL,并且没有指定默认值。
MySQL错误信息可能对调试它有用。
另一种可能性是这个语句实际上是成功的,但是在一个事务的上下文中执行,该事务随后被回滚而不是被提交。)
你的问题中没有足够的信息可以告诉你。
我建议您比较两个数据库上的表定义。最简单的方法(对我来说)是从每个数据库中获取SHOW CREATE TABLE intervention语句的输出,并寻找差异。其中一个数据库也可能有一个BEFORE INSERT FOR EACH ROW触发器,而另一个则缺少另一个。