亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > MySQL > 正文

mysql數據庫常見的優化操作總結(經驗分享)

2024-07-24 13:13:03
字體:
來源:轉載
供稿:網友

前言

對于一個以數據為中心的應用,數據庫的好壞直接影響到程序的性能,因此數據庫性能至關重要。所以mysql數據庫的優化操作大家都要有所了解,本文就主要總結了mysql數據庫中常見的優化操作,下面話不多說了,來看看詳細的介紹吧。

一、Index索引

將Index放第一位,不用說,這種優化方式我們一直都在悄悄使用,那便是主鍵索引。有時候我們可能并不在意,如果定義適合的索引,數據庫查詢性能(速度)將提高幾倍甚至幾十倍。

普通索引

作用是提高查詢速度。

建表,創建索引

CREATE TABLE tbl_name(字段名稱 字段類型 [完整性約束條件],~index [索引名] (column_name));

創建索引

CREATE INDEX index_name ON tab_name (column_name)

刪除索引

DROP INDEX index_name FROM tab_name 

查看索引

SHOW index FROM tab_name

主鍵索引

作用是加速查詢和唯一約束

建表,創建索引

CREATE TABLE tbl_name(字段名稱 字段類型 [完整性約束條件],~PRIMARY KEY(column_name));

創建索引

ALTER TABLE tab_name ADD PRIMARY KEY(column_name)

刪除索引

ALTER TABLE tab_name DROP PRIMAY KEY(column_name)

唯一索引

作用是加速查詢和唯一約束

建表,創建索引

CREATE TABLE tbl_name(字段名稱 字段類型 [完整性約束條件],~unique [索引名] (column_name));

創建索引

CREATE UNIQUE INDEX index_name ON tab_name (column_name)

刪除索引

DROP UNIQUE INDEX index_name FROM tab_name 

二、少用SELECT*

可能有的人查詢數據庫時,遇到要查詢的都會select,這是不恰當的行為。我們應該取我們要用的數據,而不是全取,因為當我們select時,會增加web服務器的負擔,增加網絡傳輸的負載,查詢速度自然就下降 。

三、EXPLAIN SELECT

對于這個功能估計很多人都沒見過,但是這里強烈推薦使用。explain顯示了mysql如何使用索引來處理select語句以及連接表??梢詭椭x擇更好的索引和寫出更優化的查詢語句。主要用發就是在select前加上explain即可。

EXPLAIN SELECT [查找字段名] FROM tab_name ...

四、開啟查詢緩存

大多數的MySQL服務器都開啟了查詢緩存。這是提高性最有效的方法之一,而且這是被MySQL的數據庫引擎處理的。當有很多相同的查詢被執行了多次的時候,這些查詢結果會被放到一個緩存中,這樣,后續的相同的查詢就不用操作表而直接訪問緩存結果了。

第一步把query_cache_type設置為ON,然后查詢系統變量have_query_cache是否可用:

show variables like 'have_query_cache'

之后,分配內存大小給查詢緩存,控制緩存查詢結果的最大值。相關操作在配置文件中進行修改。

五、使用NOT NULL

很多表都包含可為 NULL (空值) 的列,即使應用程序井不需要保存 NULL 也是如此 ,這是因為可為 NULL 是列的默認屬性。通常情況下最好指定列為 NOT NULL,除非真 的需要存儲 NULL 值。

如果查詢中包含可為 NULL 的列,對 MySQL 來說更難優化 ,因為可為 NULL 的列使 得索引、索引統計和值比較都更復雜 ??蔀镹ULL 的列會使用更多的存儲空間 ,在 MySQL 里也需要特殊處理 。當可為NULL 的列被索引肘,每個索引記錄需要一個額 外的字節,在 MyISAM 里甚至還可能導致固定大小 的索引 (例如只有一個整數列的 索引) 變成可變大小的索引。

通常把可為 NULL 的列改為 NOT NULL 帶來的性能提升比較小 ,所以 (調優時) 沒有 必要首先在現有schema中查找井修改掉這種情況 ,除非確定這會導致問題。但是, 如果計劃在列上建索引 ,就應該盡量避免設計成可為 NULL 的列。當然也有例外 ,例如值得一提的是,InnoDB 使用單獨的位 (bit ) 存儲 NULL 值 ,所 以對于稀疏數據由有很好的空間效率 。但這一點不適用于MyISAM 。

六、存儲引擎的選擇

對于如何選擇MyISAM和InnoDB,如果你需要事務處理或是外鍵,那么InnoDB可能是比較好的方式。如果你需要全文索引,那么通常來說MyISAM是好的選擇,因為這是系統內建的,然而,我們其實并不會經常地去測試兩百萬行記錄。所以,就算是慢一點,我們可以通過使用Sphinx從InnoDB中獲得全文索引。

數據的大小,是一個影響你選擇什么樣存儲引擎的重要因素,大尺寸的數據集趨向于選擇InnoDB方式,因為其支持事務處理和故障恢復。數據庫的在小決定了故障恢復的時間長短,InnoDB可以利用事務日志進行數據恢復,這會比較快。而MyISAM可能會需要

幾個小時甚至幾天來干這些事,InnoDB只需要幾分鐘。

您操作數據庫表的習慣可能也會是一個對性能影響很大的因素。比如: COUNT() 在 MyISAM表中會非???,而在InnoDB表下可能會很痛苦。而主鍵查詢則在InnoDB下會相當相當的快,但需要小心的是如果我們的主鍵太長了也會導致性能問題。大批的inserts語句在MyISAM下會快一些,但是updates在InnoDB 下會更快一些——尤其在并發量大的時候。

所以,到底你檢使用哪一個呢?根據經驗來看,如果是一些小型的應用或項目,那么MyISAM也許會更適合。當然,在大型的環境下使用MyISAM也會有很大成功的時候,但卻不總是這樣的。如果你正在計劃使用一個超大數據量的項目,而且需要事務處理或外鍵支持,那么你真的應該直接使用InnoDB方式。但需要記住InnoDB的表需要更多的內存和存儲,轉換100GB的MyISAM 表到InnoDB 表可能會讓你有非常壞的體驗。

七、避免在 where 子句中使用 or 來連接

如果一個字段有索引,一個字段沒有索引,將導致引擎放棄使用索引而進行全表掃描,如:

select id from t where num=10 or Name = 'admin'

可以這樣查詢:

select id from t where num = 10union allselect id from t where Name = 'admin'

八、多使用varchar/nvarchar

使用varchar/nvarchar代替 char/nchar ,因為首先變長字段存儲空間小,可以節省存儲空間,其次對于查詢來說,在一個相對較小的字段內搜索效率顯然要高些。

九、避免大數據量返回

這里要考慮使用limit,來限制返回的數據量,如果每次返回大量自己不需要的數據,也會降低查詢速度。

十、where子句優化

where 子句中使用參數,會導致全表掃描,因為SQL只有在運行時才會解析局部變量,但優化程序不能將訪問計劃的選擇推遲到運行時;它必須在編譯時進行選擇。然 而,如果在編譯時建立訪問計劃,變量的值還是未知的,因而無法作為索引選擇的輸入項。

應盡量避免在 where 子句中對字段進行表達式操作,避免在where子句中對字段進行函數操作這將導致引擎放棄使用索引而進行全表掃描。不要在 where 子句中的“=”左邊進行函數、算術運算或其他表達式運算,否則系統將可能無法正確使用索引。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對VeVb武林網的支持。


注:相關教程知識閱讀請移步到MYSQL教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美日韩国产一区中文午夜| 一区二区亚洲精品国产| 国产精品欧美激情在线播放| 亚洲精品久久久一区二区三区| 国产精品青草久久久久福利99| 福利一区视频在线观看| 精品视频在线导航| 国产精品普通话| 中文字幕综合在线| 国产91精品久久久久| 欧美电影免费观看电视剧大全| 国产精品久久久久久久电影| 亚洲欧美国产一本综合首页| 日本欧美爱爱爱| 久久久最新网址| 亚洲黄色av女优在线观看| 午夜精品久久久久久久白皮肤| 久久久国产精品x99av| 国产精品电影观看| 美女啪啪无遮挡免费久久网站| 欧美精品激情在线| 亚洲精品美女久久久久| 成人网中文字幕| 亚洲aaaaaa| 美女福利精品视频| 欧美精品情趣视频| 国产一区二区三区在线看| 亚洲欧美一区二区三区四区| 久久噜噜噜精品国产亚洲综合| 91影视免费在线观看| 国产精品成人一区二区| 国产欧美精品一区二区三区介绍| 97色在线视频| 日韩在线精品视频| 亚洲福利视频网| 久久夜精品香蕉| 久久亚洲欧美日韩精品专区| 国产精品视频白浆免费视频| 欧美亚洲激情在线| 一区二区三区四区精品| 91久久夜色精品国产网站| 亚洲国产精品va| 国外日韩电影在线观看| 欧美一级成年大片在线观看| 97视频网站入口| 国产亚洲视频中文字幕视频| 国产精品96久久久久久| 欧美激情视频一区二区| 91精品综合久久久久久五月天| 久久久精品2019中文字幕神马| 亚洲国产古装精品网站| 中文字幕亚洲二区| 欧美成人全部免费| 欧美精品在线看| 精品偷拍一区二区三区在线看| 国产男人精品视频| 亚洲一区二区自拍| 亚洲人午夜精品| 久久99亚洲热视| 最新国产精品亚洲| 久久伊人精品视频| 91精品在线观看视频| 国产精品久久久久不卡| 国产一区二区免费| 欧美理论电影网| 亚洲一区二区三区在线免费观看| 国产精品专区h在线观看| 国产精品永久免费观看| 亚洲欧美制服另类日韩| 欧美xxxx做受欧美| 中文亚洲视频在线| 精品视频一区在线视频| 日韩中文在线中文网三级| 亚洲第一男人天堂| 国产精品久久久久国产a级| 久久久精品在线观看| 久久在线精品视频| 日韩精品在线第一页| 国产这里只有精品| 午夜精品久久久久久久99热| 尤物yw午夜国产精品视频| 国产成人综合精品在线| 久久亚洲影音av资源网| 中文字幕日韩av| 欧美日韩激情视频8区| 狠狠色狠狠色综合日日小说| 久久精品国产精品| 精品一区精品二区| 国外视频精品毛片| 成人亚洲激情网| 亚洲欧美日韩视频一区| 美女久久久久久久久久久| 国产ts人妖一区二区三区| 91精品视频在线免费观看| 午夜精品久久久久久久久久久久| 国产午夜精品一区二区三区| 精品福利在线视频| 日韩中文字幕网址| 国产精品视频在线播放| 国产免费一区二区三区香蕉精| 一本大道亚洲视频| 91精品视频在线免费观看| 国产精品精品一区二区三区午夜版| 日韩在线观看免费全| 国产一区二区美女视频| 91亚洲国产精品| 成人激情免费在线| 久久久亚洲精品视频| 亚洲石原莉奈一区二区在线观看| 国内精品免费午夜毛片| 亚州国产精品久久久| 精品偷拍各种wc美女嘘嘘| 国产成人精品视频在线观看| 国产欧美精品在线播放| 色av中文字幕一区| xx视频.9999.com| 久久视频免费在线播放| 国产亚洲视频在线观看| 久久亚洲精品成人| 午夜精品美女自拍福到在线| 国产精品美女免费视频| 亚洲精品电影网站| 欧美激情亚洲国产| 国产精品久久久91| 国产成人在线一区二区| 亚洲一区二区三区乱码aⅴ蜜桃女| 久久精品国产99国产精品澳门| 国产亚洲一区二区精品| 91国内免费在线视频| 久久影视电视剧免费网站清宫辞电视| 欧美日韩在线视频一区| 亚洲图片欧美日产| 国产一区二区在线免费视频| 日韩免费在线观看视频| 国产偷亚洲偷欧美偷精品| 国产免费成人av| 欧美另类在线播放| 久久中文字幕在线视频| wwwwwwww亚洲| 国产欧美日韩精品在线观看| 日韩在线观看网站| 久久伊人精品一区二区三区| 欧美亚洲视频在线观看| 欧美中文字幕视频| 日韩精品极品视频| 欧美亚洲日本网站| 成人黄色在线免费| 中文字幕一区二区精品| 91日本在线观看| 欧美华人在线视频| 亚洲精品www| 国产精品99导航| 国产剧情久久久久久| 九九久久久久99精品| 久久伊人精品一区二区三区| 欧美最猛性xxxx| 精品视频久久久久久| 欧美成人在线影院| 日韩视频免费在线| 亚洲欧美日本另类| 综合网日日天干夜夜久久| 亚洲日本中文字幕免费在线不卡| 亚洲午夜色婷婷在线| 亚洲精品v欧美精品v日韩精品|