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

首頁 > 數(shù)據(jù)庫 > MySQL > 正文

mysql 查詢重復(fù)的數(shù)據(jù)的SQL優(yōu)化方案

2024-07-24 12:42:47
字體:
供稿:網(wǎng)友

 在mysql中查詢不區(qū)分大小寫重復(fù)的數(shù)據(jù),往往會用到子查詢,并在子查詢中使用upper函數(shù)來將條件轉(zhuǎn)化為大寫。如:

 

代碼如下:
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ù)以內(nèi)的10分鐘內(nèi)還能獲取到數(shù)據(jù),如果是查詢幾十萬條的話,會直接把服務(wù)器跑死的,此時可以通過一個臨時表,并且加索引,再查詢。這樣可以提高很多的速度

 

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

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 达拉特旗| 巴楚县| 三台县| 玛多县| 托克逊县| 平利县| 桂林市| 辽中县| 田阳县| 尚义县| 望奎县| 惠水县| 南溪县| 长子县| 利辛县| 潍坊市| 海城市| 团风县| 建阳市| 辽源市| 高雄市| 南木林县| 安图县| 美姑县| 丹巴县| 遂宁市| 榆中县| 乌拉特前旗| 浑源县| 文安县| 万荣县| 德昌县| 商水县| 荆门市| 宁南县| 苗栗市| 米脂县| 灌云县| 三原县| 同仁县| 积石山|