欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySql的優(yōu)化步驟介紹(推薦)

 更新時間:2016年06月22日 09:58:40   投稿:jingxian  
下面小編就為大家?guī)硪黄狹ySql的優(yōu)化步驟介紹(推薦)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

MySql優(yōu)化的一般步驟:

1.通過show status 命令了解各種sql的執(zhí)行效率

SHOW STATUS提供msyql服務器的狀態(tài)信息

一般情況下,我們只需要了解以”Com”開頭的指令

show session status like ‘Com%':顯示當前的連接的統(tǒng)計結(jié)果

show global status like ‘Com%' :顯示自數(shù)據(jù)庫上次啟動至今的統(tǒng)計結(jié)果

注:默認是session級別的

其中Com_XXX表示XXX語句所執(zhí)行的次數(shù)。

重點注意:Com_select,Com_insert,Com_update,Com_delete通過這幾個參數(shù),可以容易地了解到當前數(shù)據(jù)庫的應用是以插

入更新為主還是以查詢操作為主,以及各類的SQL大致的執(zhí)行比例是多少。

另外,還有幾個參數(shù)需要注意下:

show status like ‘Connections'// 試圖連接MySQL服務器的次數(shù)

show status like ‘Uptime'//服務器工作的時間(單位秒)

show status like ‘Slow_queries'//慢查詢的次數(shù) (默認是10秒中就當做是慢查詢,如下圖所示)

www.dbjr.com.cn

a) 如何查詢mysql的慢查詢時間

Show variables like 'long_query_time';

b) 修改mysql 慢查詢時間

set long_query_time=2//如果查詢時間超過2秒就算作是慢查詢

2. 定位執(zhí)行效率較低的SQL語句(dql出現(xiàn)問題的概率較dml的大)

問題是:如何在一個項目中,找到慢查詢的select語句?

答案:mysql支持把慢查詢語句記錄到日志文件中。程序員需要修改php.ini的配置文件,默認情況下,慢查詢記錄是不開啟的。

開啟慢查詢記錄的步驟:

打開 my.ini ,找到 [mysqld] 在其下面添加

long_query_time = 2

log-slow-queries = D:/mysql/logs/slow.log #設置把日志寫在那里,可以為空,系統(tǒng)會給一個缺省的文件

例子:我們數(shù)據(jù)表中有1千萬條的數(shù)據(jù)量

DQL語句:SELECT * FROM order_copy WHERE id=12345;

www.dbjr.com.cn

查詢耗時:19s>2s,所以mysql會將該條select語句記錄到慢查詢?nèi)罩局?/p>

SELECT * FROM order_copy WHERE id=12345的執(zhí)行時間:

添加索引前:19s

添加索引后:0.08s

3.通過explain分析低效率的SQL語句的執(zhí)行情況

使用explain分析該dql語句:

EXPLAIN SELECT * FROM order_copy WHERE id=12345

會產(chǎn)生如下信息:

select_type:表示查詢的類型。

table:輸出結(jié)果集的表

type:表示表的連接類型(system和const為佳)

possible_keys:表示查詢時,可能使用的索引

key:表示實際使用的索引

key_len:索引字段的長度

rows:掃描的行數(shù)

Extra:執(zhí)行情況的描述和說明

注意:要盡量避免讓type的結(jié)果為all,extra的結(jié)果為:using filesort

www.dbjr.com.cn

4.確定問題并采取相應的優(yōu)化措施

常用的優(yōu)化措施是添加索引。添加索引,我們不用加內(nèi)存,不用改程序,不用調(diào)sql,只要執(zhí)行個正確的'create index',查詢速度就可能提高百倍千倍。但是天下沒有免費的午餐,查詢速度的提高是以插入、更新、刪除的速度為代價的,這些寫操作,增加了大量的I/O。

例如:給字段id添加索引:

ALTER TABLE order_copy ADD PRIMARY KEY(id)

給1千萬的數(shù)據(jù)添加primary key 需要耗時: 428秒(7分鐘)

EXPLAIN SELECT * FROM order_copy WHERE id=12345

www.dbjr.com.cn

正是因為給id添加了索引,才使得rows的結(jié)果為1

但是索引并不是可以隨便添加的,以下幾種情況需牢記在心:

較頻繁的作為查詢條件字段應該創(chuàng)建索引

select * from order_copy where id = $id

唯一性太差的字段不適合單獨創(chuàng)建索引,即使頻繁作為查詢條件

select * from order_copy where sex='女'

更新非常頻繁的字段不適合創(chuàng)建索引

select * from order_copy where order_state='未付款'

不會出現(xiàn)在WHERE子句中字段不該創(chuàng)建索引

索引的類型:

PRIMARY 索引 => 在主鍵上自動創(chuàng)建INDEX 索引 => 就是普通索引UNIQUE 索引 => 相當于INDEX + UniqueFULLTEXT => 只在MYISAM 存儲引擎支持, 目的是全文索引,在內(nèi)容系統(tǒng)中用的多, 在全英文網(wǎng)站用多(英文詞獨立). 中文數(shù)據(jù)不常用,意義不大 國內(nèi)全文索引通常 使用 sphinx 來完成.

索引的使用

建立索引 create [UNIQUE|FULLTEXT] index index_name on tbl_name (col_name [(length)] [ASC | DESC] , …..);
alter table table_name ADD INDEX [index_name] (index_col_name,...)

添加主鍵(索引) ALTER TABLE 表名 ADD PRIMARY KEY(列名,..); 聯(lián)合主鍵

刪除索引 DROP INDEX index_name ON tbl_name;
alter table table_name drop index index_name;刪除主鍵(索引)比較特別: alter table t_b drop primary key;查詢索引(均可) show index from table_name;
show keys from table_name;
desc table_Name;

以上就是小編為大家?guī)淼腗ySql的優(yōu)化步驟介紹(推薦)全部內(nèi)容了,希望大家多多支持腳本之家~

您可能感興趣的文章:

相關(guān)文章

  • MySQL在哪些情況下不使用索引的示例

    MySQL在哪些情況下不使用索引的示例

    盡管索引可以顯著提高數(shù)據(jù)庫的查詢性能,但在某些情況下,MySQL可能不會使用索引,本文就來介紹一下MySQL在哪些情況下不使用索引,具有一定的參考價值,感興趣的可以了解一下
    2024-01-01
  • MySQL數(shù)據(jù)庫JDBC編程詳解流程

    MySQL數(shù)據(jù)庫JDBC編程詳解流程

    JDBC是指Java數(shù)據(jù)庫連接,是一種標準Java應用編程接口(?JAVA?API),用來連接?Java?編程語言和廣泛的數(shù)據(jù)庫。從根本上來說,JDBC?是一種規(guī)范,它提供了一套完整的接口,允許便攜式訪問到底層數(shù)據(jù)庫,本篇文章我們來了解MySQL連接JDBC的流程方法
    2022-01-01
  • MySql Online DDL操作記錄詳解

    MySql Online DDL操作記錄詳解

    這篇文章主要為大家介紹了MySql Online DDL操作記錄詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-12-12
  • Mysql刪除重復數(shù)據(jù)保留最小的id 的解決方法

    Mysql刪除重復數(shù)據(jù)保留最小的id 的解決方法

    這篇文章主要介紹了Mysql刪除重復數(shù)據(jù)保留最小的id 的解決方法,需要的朋友可以參考下
    2017-10-10
  • MYSQL之插入極限分析

    MYSQL之插入極限分析

    MYSQL之插入極限分析,需要的朋友可以參考下
    2013-02-02
  • mysql聯(lián)合索引的使用規(guī)則

    mysql聯(lián)合索引的使用規(guī)則

    本文主要介紹了mysql聯(lián)合索引的具體使用,結(jié)合實例代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-06-06
  • MySql允許遠程連接如何實現(xiàn)該功能

    MySql允許遠程連接如何實現(xiàn)該功能

    這篇文章主要介紹了 MySql允許遠程連接如何實現(xiàn)該功能的相關(guān)資料,需要的朋友可以參考下
    2017-02-02
  • MySQL數(shù)據(jù)庫給表添加索引的實現(xiàn)

    MySQL數(shù)據(jù)庫給表添加索引的實現(xiàn)

    在MySQL中,索引是用來加速數(shù)據(jù)庫查詢的一種特殊數(shù)據(jù)結(jié)構(gòu),當我們需要查詢數(shù)據(jù)庫中某些數(shù)據(jù)的時候,如果數(shù)據(jù)庫中有索引,就可以避免全表掃描,從而提高查詢速度,本文就介紹了如何給表添加索引,感興趣的可以了解一下
    2023-08-08
  • Mac上安裝MySQL過程分享

    Mac上安裝MySQL過程分享

    這篇文章主要介紹了Mac上安裝MySQL過程分享,本文共分4步完成,簡單易懂,需要的朋友可以參考下
    2014-11-11
  • CentOS6.5下RPM方式安裝mysql5.6.33的詳細教程

    CentOS6.5下RPM方式安裝mysql5.6.33的詳細教程

    本文給大家詳細介紹CentOS6.5下RPM方式安裝mysql5.6.33的教程,本文分步驟給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友一起看看吧
    2016-10-10

最新評論