2011-01-05 15 views
5

Estoy intentando eliminar todos los registros que no son la última versión bajo su nombre pero aparentemente no puede hacer referencia al acceso a una tabla que está modificando en la misma consulta.Obtenga una autorrefensa en una consulta DELETE

He intentado esto, pero no funciona por las razones anteriores:

DELETE FROM table 
WHERE CONCAT(name, version) NOT IN (
SELECT CONCAT(name, MAX(version)) 
FROM table 
GROUP name 
) 

Como puedo evitar esto?

Saludos

Respuesta

7

Wrap the inner reference in a derived table.

DELETE FROM table 
WHERE Concat(name, version) NOT IN (SELECT nv 
            FROM (SELECT Concat(name, Max(version)) 
                AS nv 
              FROM table 
              GROUP BY name) AS derived) 
+1

Gracias, había visto ese enlace y probado este método anterior pero debe haber dejado un soporte fuera de lugar en alguna parte. – DonutReply

+0

acaba de darse cuenta y editado – DonutReply

1
delete t1 
from table_name1 t1, table_name1 t2 
where t1.version < t2.version 
and t1.name = t2.name; 

// creando alias es la necesidad aquí

Cuestiones relacionadas