mysql - 可以从存储过程中使用动态 SQL 创建 MySQL 触发器吗?

标签 mysql triggers dynamic-sql

是否可以使用从存储过程中动态生成的 SQL 在 MySQL 中创建触发器?我通过准备语句在我的过程中执行其他动态构造的查询,但是当我尝试使用相同的方法创建触发器时,出现以下错误:

ERROR Code: 1295This command is not supported in the prepared statement protocol yet

来自 Bug #31625, PREPARED STATEMENT syntax does not allow to create TRIGGERS 我看到其他人自 2007 年以来一直在提示同样的事情。

的外观来看 WL#2871: Prepare any SQL 尚未修复。

这个问题有解决办法吗?是否有另一种使用动态 SQL 创建触发器的方法?

基本上我想做的是动态创建触发器来记录审计数据,以便在各种不同的表上插入。我在 *audit_tables* 表中列出了我要审计的表。下面的精简过程迭代该表中的条目并尝试创建触发器。

drop procedure if exists curtest;
delimiter |
create procedure curtest()
BEGIN
    DECLARE done INT DEFAULT 0;
    declare tn varchar(16);
    declare cur cursor for select table_name from audit_tables;
    DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1;
    OPEN cur;
    read_loop: LOOP
        fetch cur into tn;
        if done then
            leave read_loop;
        end if;

        /* Create the BEFORE INSERT trigger */
        set @sql = concat('CREATE TRIGGER audit_', tn, '_bi BEFORE INSERT ON ', tn, '
            FOR EACH ROW BEGIN
                set new.foo="bar";
            END;');
        PREPARE stmt FROM @sql;
        EXECUTE stmt;
        DEALLOCATE  PREPARE stmt;
    end LOOP;
    close cur;
END;
|
delimiter ;

call curtest();

最佳答案

正如您提到的错误所说,准备好的语句中不支持 CREATE TRIGGER 命令。

我认为更可行的选择是使用具有 MySQL 绑定(bind)的脚本语言(如 PHP)来自动创建触发器。顺便说一句,我只记得 MySQL Workbench 使用 Lua 作为这类事情的脚本语言。

关于mysql - 可以从存储过程中使用动态 SQL 创建 MySQL 触发器吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5981396/

相关文章:

mysql - 在 Electron 中使用 mysql

sql - 仅允许从触发器内插入

oracle - 如何从立即执行语句的输出中获取结果

mysql - 得分+当前玩家得分排名前10的玩家

mysql - 表中开始日期和结束日期之间的周末事件

azure - 如何从 Synapse Pipelines 触发 ADF Pipeline

用于插入和更新的 MySQL Fire 触发器

sql - 如何从动态查询插入表?

SQL从另一个表的字段更新一个表的字段

mysql :Exclude row that does not satisfy the condition list