MySQL 條件插入:僅在唯一時插入
MySQL 對條件插入提供有限的支援。在這種特定情況下,您的目標是僅當使用者和項目的組合不存在時才向 x_table 中插入行。
MySQL 的 INSERT 語句不允許直接條件插入。但是,您可以使用子查詢來解決此問題。一種方法是使用 NOT EXISTS 子句:
INSERT INTO x_table (instance, user, item) SELECT 919191, 123, 456 FROM dual WHERE NOT EXISTS ( SELECT * FROM x_table WHERE user = 123 AND item = 456 );
在此查詢中,帶有 NOT EXISTS 的子查詢檢查指定的使用者和項目是否已存在於 x_table 中。如果不這樣做,將插入新行。否則,什麼事也不會發生。
另一個選項是使用 MERGE 語句,它允許在單一語句中指定條件插入和更新操作。然而,MySQL 僅支援 MERGE 作為擴展,而不是核心功能的一部分。
以上是如何在 MySQL 中執行條件 INSERT 以確保行唯一?的詳細內容。更多資訊請關注PHP中文網其他相關文章!