mysql触发器把一张表插入的一个数据添加到另一张表

表saj_iot_payment新增数据中把PAY_TIME字段添加到表saj_iot_order_iotaccount中,条件是saj_iot_order_iotaccount的order_id和saj_iot_payment的order_no对应

DELIMITER $$


USE `sajsite`$$

DROP TRIGGER /*!50032 IF EXISTS */ `updatepaydate`$$

CREATE
    /*!50017 DEFINER = 'saj'@'%' */
    TRIGGER `updatepaydate` AFTER INSERT ON `saj_iot_payment`
    FOR EACH ROW BEGIN
update
`saj_iot_order_iotaccount`
set
pay_time =new.PAY_TIME
where
order_id = new.ORDER_NO;
    END;
$$

DELIMITER ;
可以使用MySQL触发器来实现当一个发生插入或更新时,将数据同步到另一张中的功能。触发器是在执行INSERT、UPDATE或DELETE语句时自动执行的一段程序。以下是一个简单的例子: 假设我们有两个一个是employees,另一个是employee_audit。当employees发生插入或更新时,我们需要将数据同步到employee_audit中。 首先,我们需要在employee_audit中创建一个与employees相同的结构。然后,我们可以使用以下代码创建一个触发器: ``` CREATE TRIGGER sync_employee_audit AFTER INSERT ON employees FOR EACH ROW BEGIN INSERT INTO employee_audit (employee_id, name, age, salary) VALUES (NEW.employee_id, NEW.name, NEW.age, NEW.salary); END; ``` 这个触发器会在employees插入一行数据时自动执行。它会将插入数据同步到employee_audit中。 同样,我们可以创建一个类似的触发器来处理employees的更新操作: ``` CREATE TRIGGER sync_employee_audit AFTER UPDATE ON employees FOR EACH ROW BEGIN UPDATE employee_audit SET name = NEW.name, age = NEW.age, salary = NEW.salary WHERE employee_id = OLD.employee_id; END; ``` 这个触发器会在employees中更新一行数据时自动执行。它会将更新的数据同步到employee_audit中。 需要注意的是,当使用触发器时,需要确保数据库的性能不会受到影响。如果数据量很大,可能需要使用其他技术来处理数据同步。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值