如果“更改”是指行已更新、删除或插入,则存在解决方法。
可以在MySQL中创建触发器DELIMITER $$
CREATE TRIGGER ai_tablename_each AFTER INSERT ON tablename FOR EACH ROW
BEGIN
DECLARE exec_result integer;
SET exec_result = sys_exec(CONCAT('my_cmd '
,'insert on table tablename '
,',id=',new.id));
IF exec_result = 0 THEN BEGIN
INSERT INTO table_external_result (id, tablename, result)
VALUES (null, 'tablename', 0)
END; END IF;
END$$
DELIMITER ;
这将调用服务器上的可执行脚本my_cmd。(请参阅sys_exec fro more info)和一些参数。
my cmd可以是Python程序,也可以是使用MySQL使用的用户帐户从命令行执行的任何东西。
您必须为您希望程序收到通知的每个更改(INSERT/UPDATE/DELETE)和每个表创建一个触发器。
此外,您还需要找到某种方法,将正在运行的Python程序链接到通过sys_exec()调用的命令行实用程序。
不推荐
不推荐这种行为,因为它可能:减慢MySQL速度
如果我的命令不返回,则使其挂起/超时
如果您正在使用transaction,则会在事务结束之前通知您
如果事务回滚,我不确定是否会通知您delete
这是个丑陋的设计