第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問(wèn)題,去搜搜看,總會(huì)有你想問(wèn)的

相當(dāng)于MySQL中Oracle的RowID

相當(dāng)于MySQL中Oracle的RowID

蝴蝶不菲 2019-12-05 15:56:48
在mysql中是否有相當(dāng)于Oracle的rowid?delete from my_table where rowid not in (select max(rowid) from my_table group by field1,field2)我想做一個(gè)MySQL等效于此查詢?。?!我想做的是::my_table沒(méi)有主鍵..我正試圖刪除重復(fù)的值并強(qiáng)加一個(gè)主鍵(field1和field2的復(fù)合)。
查看完整描述

3 回答

?
慕蓋茨4494581

TA貢獻(xiàn)1850條經(jīng)驗(yàn) 獲得超11個(gè)贊

也許,我誤解了問(wèn)題,但是您的查詢(即使在Oracle中)也無(wú)法實(shí)現(xiàn)您想要的目標(biāo):


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

my_table group by field1,field2)

相當(dāng)于MySQL


SELECT @rowid:=max(rowid) from my_table;

DELETE FROM my_table where rowid != @rowid;

這將清除除最后一行以外的所有行。


要執(zhí)行一次數(shù)據(jù)清理(刪除重復(fù)記錄),您可以執(zhí)行以下操作:


CREATE TABLE my_table2 SELECT distinct f1, f2, f3, etc from my_table;

DROP TABLE my_table;

ALTER TABLE my_table2 RENAME my_table;

然后通過(guò)ALTER TABLE添加任何必要的列和鍵。上面的代碼可能需要?jiǎng)h除您可能擁有的任何外鍵。


查看完整回答
反對(duì) 回復(fù) 2019-12-05
?
人到中年有點(diǎn)甜

TA貢獻(xiàn)1895條經(jīng)驗(yàn) 獲得超7個(gè)贊

您可以使用另一個(gè)派生表來(lái)避免臨時(shí)表:


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


查看完整回答
反對(duì) 回復(fù) 2019-12-05
  • 3 回答
  • 0 關(guān)注
  • 919 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)