猿问

相当于MySQL中Oracle的RowID

在mysql中是否有相当于Oracle的rowid?

delete from my_table where rowid not in (select max(rowid) from my_table group by field1,field2)

我想做一个MySQL等效于此查询!!!

我想做的是::my_table没有主键..我正试图删除重复的值并强加一个主键(field1和field2的复合)。


蝴蝶不菲
浏览 885回答 3
3回答

慕盖茨4494581

也许,我误解了问题,但是您的查询(即使在Oracle中)也无法实现您想要的目标:delete from my_table where rowid not in (select max(rowid) from my_table group by field1,field2)相当于MySQLSELECT @rowid:=max(rowid) from my_table;DELETE FROM my_table where rowid != @rowid;这将清除除最后一行以外的所有行。要执行一次数据清理(删除重复记录),您可以执行以下操作:CREATE TABLE my_table2 SELECT distinct f1, f2, f3, etc from my_table;DROP TABLE my_table;ALTER TABLE my_table2 RENAME my_table;然后通过ALTER TABLE添加任何必要的列和键。上面的代码可能需要删除您可能拥有的任何外键。

人到中年有点甜

您可以使用另一个派生表来避免临时表:DELETE FROM my_table USING my_table JOIN (    SELECT @rowid:=IF(@f1=field1 AND @f2=field2, @rowid+1, 0) as rowid,        @f1:=field1 as field1,        @f2:=field2 as field2,       some_row_uid   FROM testruns t, (SELECT @rowid:=NULL, @f1:=NULL, @f2:=NULL) as init   ORDER BY field1, field2 DESC) as duplicatesON my_table.some_row_uid = duplicates.some_row_uid AND duplicates.rowid > 0
随时随地看视频慕课网APP

相关分类

MySQL
我要回答