python如何获取mysql信息_python:如何获取mysql数据库更改的通知?

如果“更改”是指行已更新、删除或插入,则存在解决方法。

可以在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

这是个丑陋的设计

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值