文章詳情頁
group-by - mysql group by 優化的問題
瀏覽:106日期:2022-06-14 17:40:23
問題描述
我有一張接近八千萬條數據的彩虹表,然后里面有二十多萬條的重復數據,我想使用GROUP BY 進行分組,但是使用了GROUP BY語句以后,mysql會生出一張零時表,而零時表,把我的硬盤全部沾滿了,所以,求個辦法,能幫去去處這重復的數據?
我的sql:
sql:
SELECT COUNT(id) FROM password WHERE length = 4 GROUP BY ciphertext
問題解答
回答1:不贊成用一條SQL語句來搞定這類問題,因為數據庫耗不起。可以用程序來實現(比如寫個Python腳本),步驟是這樣的:
把表A(8千萬行)復制一個表結構,產生一張空表B;
對B的ciphertext列做唯一索引;
遍歷表A的每一行,插入到表B,可以用REPLACE或INSERT INTO ... ON DUPLICATE KEY UPDATE ...
校驗表B的數據,如果結果正確,則刪除表A,把表B重命名為表A。
相關文章:
1. mysql - 分庫分表、分區、讀寫分離 這些都是用在什么場景下 ,會帶來哪些效率或者其他方面的好處2. css - 移動端 oppo 手機之 Border-radius3. 關于Mysql聯合查詢4. python 計算兩個時間相差的分鐘數,超過一天時計算不對5. 人工智能 - python 機器學習 醫療數據 怎么學6. 如何修改phpstudy的phpmyadmin放到其他地方7. javascript - vue-echarts-v3使用的過程中折線圖區域呈漸變色。8. 爬蟲圖片 - 關于Python 爬蟲的問題9. pip安裝提示Twisted錯誤問題(Python3.6.4安裝Twisted錯誤)10. c++ - 請問MySQL_Connection::isReadOnly 怎么解決?
排行榜
