Wykonuję zapytanie wstawiające, w którym większość z wielu kolumn musiałaby zostać zaktualizowana do nowych wartości, jeśli unikatowy klucz już istniał. To wygląda mniej więcej tak:
INSERT INTO lee(exp_id, created_by,
location, animal,
starttime, endtime, entct,
inact, inadur, inadist,
smlct, smldur, smldist,
larct, lardur, lardist,
emptyct, emptydur)
SELECT id, uid, t.location, t.animal, t.starttime, t.endtime, t.entct,
t.inact, t.inadur, t.inadist,
t.smlct, t.smldur, t.smldist,
t.larct, t.lardur, t.lardist,
t.emptyct, t.emptydur
FROM tmp t WHERE uid=x
ON DUPLICATE KEY UPDATE ...;
//update all fields to values from SELECT,
// except for exp_id, created_by, location, animal,
// starttime, endtime
Nie jestem pewien, jaka UPDATE
powinna być składnia klauzuli. Jak mam odwołać się do bieżącego wiersza z SELECT
klauzuli?
mysql
insert-update
dnagirl
źródło
źródło
t.
jest wymagana. Znalazłem również artykuł o xaprb ( xaprb.com/blog/2006/02/21/flexible-insert-and-update-in-mysql ), który używa tej składni:on duplicate key update b = values(b), c = values(c)
. To też działa.Chociaż jestem na to bardzo spóźniony, ale po zobaczeniu kilku uzasadnionych pytań dla tych, którzy chcieli użyć
INSERT-SELECT
zapytania zGROUP BY
klauzulą, wymyśliłem obejście tego problemu .Biorąc dalej odpowiedź Marcusa Adamsa i rozliczając się
GROUP BY
w niej, w ten sposób rozwiązałbym problem za pomocąSubqueries in the FROM Clause
źródło