本篇內容主要講解“MySQL數(shù)據(jù)庫優(yōu)化語句”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“mysql數(shù)據(jù)庫優(yōu)化語句”吧!
目前創(chuàng)新互聯(lián)公司已為上千多家的企業(yè)提供了網站建設、域名、虛擬主機、網站托管、服務器租用、企業(yè)網站設計、洛隆網站維護等服務,公司將堅持客戶導向、應用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。
mysql優(yōu)化語句
數(shù)據(jù)庫語句:
Ddl(數(shù)據(jù)定義語言) alter create drop
Dml(數(shù)據(jù)操作語言) inset delete update
Dtl(數(shù)據(jù)事務語言) conmmit rollback savepoint
Select
Dcl(數(shù)據(jù)控制語句) grant賦權限 revoke回收
Mysql數(shù)據(jù)庫優(yōu)化:
1、 數(shù)據(jù)庫表 要設計合理(符合3NF,有時候也需要適當?shù)哪娣妒剑?br/>2、 Sql語句的優(yōu)化(索引,常用小技巧)
3、 數(shù)據(jù)庫的配置
4、 適當?shù)挠布渲煤筒僮飨到y(tǒng)
5、 讀寫分離
問:什么是數(shù)據(jù)庫3范式?
1NF: 就是具有原子性,不可分割(只要使用的是關系型數(shù)據(jù)庫,就會自動符合)
2NF: 在滿足1NF的基礎上,我們考慮是否滿足2NF,只要表的記錄滿足唯一性,也就是說,你的同一張表中不可能出現(xiàn)完全相同的記錄,一般說我們在表中設計一個主鍵即可。
3NF: 在滿足2NF: 的基礎上,我們考慮是否滿足3NF,既我們的字段信息可以通過關聯(lián)的關系,派生即可(通常我們通過外鍵來處理)使用外鍵數(shù)據(jù)庫的存儲引擎必須是innoDB
問2:數(shù)據(jù)庫參數(shù)配置
對于innodb存儲引擎最重要的就是內存,所以下面的兩個參數(shù)調的很大
Innodb_additional_mem_pool_size = 64M www.2cto.com
Innodb_buffer_pool_size = 1G 緩沖池大小
對于myisam,需要調整key_buffer_size
用show status 語句可以看到當前狀態(tài),以決定調整那些參數(shù)
一、顯示你使用過多少次insert , update , delete 等
Sql: show status like “Com”;
//在命令窗口中不關閉的時候查詢會準確,如果關閉就會從新開始統(tǒng)計
Show sessionstatus like “Com_update”;
//就算關閉窗口也會將全部的你執(zhí)行過的次數(shù)統(tǒng)計出來
Show globalstatus like “Com_insert”;
Example: session
假如已經使用了6次update
1、 用session統(tǒng)計 會是6次
如果關閉后命令窗口后在執(zhí)行Show session statuslike “Com_update”; 就為0了
2、 但是如果用Show global status like “Com_insert”;就是6次
二、顯示試圖連接Mysql服務器的次數(shù)
Show status like “Connections”;
數(shù)據(jù)庫啟動多長時間了
Show status like “uptime”;
顯示慢查詢多少次(默認是10秒)
Show status like “Slow_queries”;
四、如何在一個項目中,找到慢查詢的select,數(shù)據(jù)庫支持把慢查詢的語句記錄到日志中,供程序員來分析 www.2cto.com
步驟:
1、 啟動mysql(特殊的啟動方式)
a) 在mysql的安裝目錄下的bin目錄下啟動mysqld.exe –slow-query
b) Netstat –an 查看3306端口是否啟動
c) 查詢慢查詢的次數(shù) show status like “Slow_queries”;
d) 設置慢查詢的時間 set long_query_time=1;
索引優(yōu)化:
比如說增加主鍵索引
Alter table user add primary key(id);
刪除主鍵索引
Alter table user drop primary key
刪除索引
Alter table user drop index 索引名
顯示索引
Show index(es) from 表名
Show keys from 表名
Desc 表名
增加索引致使查詢會變快好多,其原理就像一本書如果沒有目錄的話那么如果你想找一個知識點會很難找到,只能一點一點的翻著找,如果有目錄的話會很快的定位到這個知識點在那個章節(jié)中大概什么位置這樣查詢起來自然就會快了啊,但是有利必有弊,索引會對查詢帶來好處,但是對add update delete 來說自然就很麻煩了,比如說你添加一個知識點,你不許還有在目錄中添加他是屬于那章那節(jié)中的那個知識點,同樣在修改和刪除的時候也會隨之改變,來保持信息的準確性。
一個自動分析是否需要使用索引的命令:explain
Example: explain select * from emp where id = 9;
索引的分類:
主鍵索引(primary key)
唯一鍵索引(unique)
Index(普通索引)
全文索引(fulltext)
復合索引(多列和在一起)
在那些列上添加索引比較合適:
1、比較頻繁的作為查詢條件的字段應該加上索引
2、 唯一性比較差的字段不適合單獨創(chuàng)建索引,及時頻繁作為查詢條件
3、 更新非常頻繁的字段不適合創(chuàng)建索引
4、 不會出現(xiàn)在where子句中的字段不該創(chuàng)建索引
查詢一個表中的所有索引: show indexes from table(表名)
索引的使用:
查詢要使用索引最重要的條件是查詢條件中需要使用索引
以下幾種情況可能會使用到索引
1、 對于創(chuàng)建的多列索引,只要查詢條件使用了最左邊的列,索引一般就會被使用
2、 對于使用like的查詢,查詢如果是‘%aaa’不會使用到索引‘aaa%’會使用到索引
以下的表中將不使用索引
1、 如果條件中有or,即使其中有條件帶索引也不會使用
2、 對于多列索引,不是使用的第一部分,則不會使用索引
3、 Like查詢是以%開頭
4、 如果列類型是字符串,那么一定要在條件中將數(shù)據(jù)使用引號引起來,否則不使用索引。
5、 如果mysql估計使用全表掃描要比使用索引快,則不使用索引。
查看索引的使用情況
Show status like ‘handler_read%’;
只有handler_read_key 越大越好
Handler_read_rnd_next 越小越好
數(shù)據(jù)庫類型:
MyISAM 不支持事務和外鍵,一張表由三個文件組成,.frm .myi .myd
innoDB 支持事務和外鍵
對于MyISAM來說查詢快,不過刪除字段時空間是不會釋放的,必須使用手動釋放 optimize table table_name
到此,相信大家對“mysql數(shù)據(jù)庫優(yōu)化語句”有了更深的了解,不妨來實際操作一番吧!這里是創(chuàng)新互聯(lián)網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續(xù)學習!