国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > MySQL > 正文

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

2024-07-24 13:06:47
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了mysql 查詢重復的數據的SQL優化方案,非常不錯的方案推薦給大家。
 

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


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 宁河县| 桃园县| 抚松县| 云林县| 塔城市| 徐水县| 天峻县| 怀远县| 治多县| 武清区| 古浪县| 合阳县| 澄江县| 波密县| 习水县| 正镶白旗| 清新县| 湘潭县| 秦安县| 五华县| 台前县| 博野县| 金乡县| 宝应县| 和静县| 舒兰市| 晋州市| 铁岭市| 上饶市| 铜梁县| 牟定县| 和硕县| 钦州市| 南木林县| 伊金霍洛旗| 城固县| 洮南市| 杨浦区| 西昌市| 子洲县| 曲靖市|