亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

請教一下相當于MySQL中Oracle的RowID

請教一下相當于MySQL中Oracle的RowID

守著一只汪 2019-12-29 04:00:05
在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的復合)。
查看完整描述

3 回答

?
開心每一天1111

TA貢獻1836條經驗 獲得超13個贊

也許,我誤解了問題,但是您的查詢(即使在Oracle中)也無法實現您想要的目標:


delete from my_table where rowid not in (select max(rowid) from 

my_table group by field1,field2)

相當于MySQL


SELECT @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添加任何必要的列和鍵。上面的代碼可能需要刪除您可能擁有的任何外鍵。



查看完整回答
反對 回復 2020-01-06
?
阿晨1998

TA貢獻2037條經驗 獲得超6個贊

您可以使用另一個派生表來避免臨時表:


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 duplicates

ON my_table.some_row_uid = duplicates.some_row_uid AND duplicates.rowid > 0



查看完整回答
反對 回復 2020-01-06
  • 3 回答
  • 0 關注
  • 710 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號