程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> 關於MYSQL數據庫 >> mysql 查詢重復的數據的SQL優化方案

mysql 查詢重復的數據的SQL優化方案

編輯:關於MYSQL數據庫

     在mysql中查詢不區分大小寫重復的數據,往往會用到子查詢,並在子查詢中使用upper函數來將條件轉化為大寫。如:

     

    代碼如下:
    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;

     

    這條語句的執行效率是非常低的,特別是Source字段沒有加索引。尤其是最忌諱的在查詢條件中使用了函數,這將極大的降低查詢速度,如果查詢十萬條數據以內的10分鐘內還能獲取到數據,如果是查詢幾十萬條的話,會直接把服務器跑死的,此時可以通過一個臨時表,並且加索引,再查詢。這樣可以提高很多的速度

     

    代碼如下:
    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優化方案的全部內容了,希望大家能夠喜歡。

    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved