INSERT INTO ... SELECT FROM ... ON DUPLICATE KEY UPDATE
-
20-09-2019 - |
Pregunta
Me estoy haciendo una consulta de inserción donde la mayor parte de las muchas columnas tendría que ser actualizado a los nuevos valores si ya existía una clave única. Es algo parecido a esto:
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
No estoy seguro de lo que debería ser la sintaxis de la cláusula UPDATE
. ¿Cómo refiero a la fila actual de la cláusula SELECT
?
Solución
MySQL asumirá la parte antes de los iguales hace referencia a las columnas nombradas en la cláusula INSERT INTO, y la segunda parte hace referencia a las columnas SELECT.
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 entct=t.entct, inact=t.inact, ...
Otros consejos
Aunque soy muy tarde para esto, pero después de ver algunas preguntas legítimas para aquellos que querían utilizar INSERT-SELECT
consulta con la cláusula GROUP BY
, me ocurrió con el trabajo en torno a esto.
Teniendo aún más la respuesta de Marcus Adams y GROUP BY
contabilidad en ella, esto es cómo iba a resolver el problema mediante el uso de Subqueries in the FROM Clause
INSERT INTO lee(exp_id, created_by, location, animal, starttime, endtime, entct,
inact, inadur, inadist,
smlct, smldur, smldist,
larct, lardur, lardist,
emptyct, emptydur)
SELECT sb.id, uid, sb.location, sb.animal, sb.starttime, sb.endtime, sb.entct,
sb.inact, sb.inadur, sb.inadist,
sb.smlct, sb.smldur, sb.smldist,
sb.larct, sb.lardur, sb.lardist,
sb.emptyct, sb.emptydur
FROM
(SELECT id, uid, location, animal, starttime, endtime, entct,
inact, inadur, inadist,
smlct, smldur, smldist,
larct, lardur, lardist,
emptyct, emptydur
FROM tmp WHERE uid=x
GROUP BY location) as sb
ON DUPLICATE KEY UPDATE entct=sb.entct, inact=sb.inact, ...