首頁  >  文章  >  資料庫  >  MySQL中插入新行後如何更新同一個表中的行?

MySQL中插入新行後如何更新同一個表中的行?

Linda Hamilton
Linda Hamilton原創
2024-10-30 06:58:18795瀏覽

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中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn