首页 > 数据库 > mysql教程 > MySQL中插入新行后如何更新同一个表中的行?

MySQL中插入新行后如何更新同一个表中的行?

Linda Hamilton
发布: 2024-10-30 06:58:18
原创
858 人浏览过

How to Update a Row in the Same Table after Inserting a New Row in MySQL?

MySQL 触发器:为新行设置值并更新同一个表中的另一行

在 MySQL 中,触发器是强大的机制,允许您当表中发生某些事件时执行特定操作。一个常见的用例是为新插入的行 (NEW) 设置值,同时更新同一表中的另一行。但是,尝试此操作时可能会出现常见错误:

错误 1442:无法更新存储函数/触发器中的表“split”,因为它已被调用此存储函数/触发器的语句使用。

出现此错误是因为触发器无法更新触发它的同一个表。要克服此限制,请遵循以下替代方法:

使用存储过程:

创建一个处理插入和更新操作的存储过程,而不是使用触发器。下面是一个示例:

<code class="sql">DELIMITER $$
CREATE PROCEDURE split_before_ins(IN startDate DATE, IN endDate DATE, IN tcOfficeFee DECIMAL, IN globalFee DECIMAL)
BEGIN
  -- Insert a new row with the provided parameters
  INSERT INTO im.split (startDate, endDate, tcOfficeFee, globalFee)
  VALUES (startDate, endDate, tcOfficeFee, globalFee);
  
  -- Update the previous row's endDate
  UPDATE im.split
  SET endDate = DATE_SUB(startDate, INTERVAL 1 DAY)
  WHERE procKey = (SELECT procKey FROM im.split ORDER BY procKey DESC LIMIT 1)
  AND endDate = '20501231';
END$$
DELIMITER ;</code>
登录后复制

过程用法:

要调用存储过程,请执行以下命令:

<code class="sql">CALL split_before_ins('2023-01-01', '2024-12-31', 10.00, 100.00);</code>
登录后复制

此存储过程方法允许您在单个事务上下文中执行所需的操作,避免使用触发器更新调用它的同一个表时遇到的错误。

以上是MySQL中插入新行后如何更新同一个表中的行?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板