mysql 查詢重復的數(shù)據(jù)的SQL優(yōu)化方案
更新時間:2015年02月12日 11:30:36 投稿:hebedich
這篇文章主要介紹了mysql 查詢重復的數(shù)據(jù)的SQL優(yōu)化方案,非常不錯的方案推薦給大家。
在mysql中查詢不區(qū)分大小寫重復的數(shù)據(jù),往往會用到子查詢,并在子查詢中使用upper函數(shù)來將條件轉化為大寫。如:
復制代碼 代碼如下:
select * from staticcatalogue WHERE UPPER(Source) IN (SELECT UPPER(Source) FROM staticcatalogue GROUP BY UPPER(Source) having count(UPPER(Source))>1) ORDER BY upper(Source) DESC;
這條語句的執(zhí)行效率是非常低的,特別是Source字段沒有加索引。尤其是最忌諱的在查詢條件中使用了函數(shù),這將極大的降低查詢速度,如果查詢十萬條數(shù)據(jù)以內的10分鐘內還能獲取到數(shù)據(jù),如果是查詢幾十萬條的話,會直接把服務器跑死的,此時可以通過一個臨時表,并且加索引,再查詢。這樣可以提高很多的速度
復制代碼 代碼如下:
CREATE TABLE staticcatalogue_tmp SELECT UPPER(Source) AS Source FROM staticcatalogue GROUP BY UPPER(Source) having count(UPPER(Source))>1;
ALTER TABLE staticcatalogue_tmp add INDEX TX_1 (Source);
select s.* from staticcatalogue s WHERE UPPER(s.Source) IN (SELECT st.Source FROM staticcatalogue_tmp st) ORDER BY UPPER(s.Source) DESC ;
以上就是本文sql優(yōu)化方案的全部內容了,希望大家能夠喜歡。
相關文章
MySQL配置了雙主,是如何避免出現(xiàn)數(shù)據(jù)回環(huán)沖突的
這篇文章主要介紹了MySQL配置了雙主,是如何避免出現(xiàn)數(shù)據(jù)回環(huán)沖突的,幫助大家更好的理解和使用MySQL數(shù)據(jù)庫,感興趣的朋友可以了解下2021-01-01