Tôi không nghĩ có cách nào để bỏ qua hành vi này của INSERT ... ON DUPLICTE KEY UPDATE
.
Tuy nhiên, bạn có thể đặt hai câu lệnh, một câu lệnh UPDATE
và một INSERT
, trong một giao dịch
:
START TRANSACTION ;
UPDATE pages
SET etc = 'randomness'
WHERE name = 'bob' ;
INSERT INTO pages (name, etc)
SELECT
'bob' AS name
, 'randomness' AS etc
FROM dual
WHERE NOT EXISTS
( SELECT *
FROM pages p
WHERE p.name = 'bob'
) ;
COMMIT ;