《Mysql必讀mysql 查詢重復的數據的SQL優化方案》要點:
本文介紹了Mysql必讀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;
MYSQL數據庫這條語句的執行效率是非常低的,特別是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 ;
MYSQL數據庫以上便是本文sql優化方案的全部內容了,希望大家能夠喜歡.
維易PHP培訓學院每天發布《Mysql必讀mysql 查詢重復的數據的SQL優化方案》等實戰技能,PHP、MYSQL、LINUX、APP、JS,CSS全面培養人才。
轉載請注明本頁網址:
http://www.snjht.com/jiaocheng/9910.html