久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

PHP數(shù)據(jù)庫(kù)編程之MySQL優(yōu)化策略概述

這篇文章主要介紹了PHP數(shù)據(jù)庫(kù)編程之MySQL優(yōu)化策略,簡(jiǎn)單講述了mysql優(yōu)化的簡(jiǎn)單技巧以及索引優(yōu)化、查詢優(yōu)化、存儲(chǔ)優(yōu)化等相關(guān)操作技巧,需要的朋友可以參考下

本文簡(jiǎn)單講述了PHP數(shù)據(jù)庫(kù)編程之MySQL優(yōu)化策略。分享給大家供大家參考,具體如下:

前些天看到一篇文章說(shuō)到PHP的瓶頸很多情況下不在PHP自身,而在于數(shù)據(jù)庫(kù)。我們都知道,PHP開(kāi)發(fā)中,數(shù)據(jù)的增刪改查是核心。為了提升PHP的運(yùn)行效率,程序員不光需要寫出邏輯清晰,效率很高的代碼,還要能對(duì)query語(yǔ)句進(jìn)行優(yōu)化。雖然我們對(duì)數(shù)據(jù)庫(kù)的讀取寫入速度上卻是無(wú)能為力,但在一些數(shù)據(jù)庫(kù)類擴(kuò)展像memcache、mongodb、redis這樣的數(shù)據(jù)存儲(chǔ)服務(wù)器的幫助下,PHP也能達(dá)到更快的存取速度,所以了解學(xué)習(xí)這些擴(kuò)展也是非常必要,這一篇先說(shuō)一下MySQL常見(jiàn)的優(yōu)化策略。

幾條MySQL小技巧

1、SQL語(yǔ)句中的關(guān)鍵詞最好用大寫來(lái)書寫,第一易于區(qū)分關(guān)鍵詞和操作對(duì)象,第二,SQL語(yǔ)句在執(zhí)行時(shí),MySQL會(huì)將其轉(zhuǎn)換為大寫,手動(dòng)寫大寫能增加查詢效率(雖然很小)。
2、如果我們們經(jīng)對(duì)數(shù)據(jù)庫(kù)中的數(shù)據(jù)行進(jìn)行增刪,那么會(huì)出現(xiàn)數(shù)據(jù)ID過(guò)大的情況,用ALTER TABLE tablename AUTO_INCREMENT=N,使自增ID從N開(kāi)始計(jì)數(shù)。
3、對(duì)int類型添加 ZEROFILL 屬性可以對(duì)數(shù)據(jù)進(jìn)行自動(dòng)補(bǔ)0
4、導(dǎo)入大量數(shù)據(jù)時(shí)最好先刪除索引再插入數(shù)據(jù),再加入索引,不然,mysql會(huì)花費(fèi)大量時(shí)間在更新索引上。
5、創(chuàng)建數(shù)據(jù)庫(kù)書寫sql語(yǔ)句時(shí) ,我們可以在IDE里創(chuàng)建一個(gè)后綴為.sql的文件,IDE會(huì)識(shí)別sql語(yǔ)法,更易于書寫。更重要的是,如果你的數(shù)據(jù)庫(kù)丟失了,你還可以找到這個(gè)文件,在當(dāng)前目錄下使用/path/mysql -uusername -ppassword databasename < filename.sql來(lái)執(zhí)行整個(gè)文件的sql語(yǔ)句(注意-u和-p后緊跟用戶名密碼,無(wú)空格)。

數(shù)據(jù)庫(kù)設(shè)計(jì)方面優(yōu)化

1、數(shù)據(jù)庫(kù)設(shè)計(jì)符合第三范式,為了查詢方便可以有一定的數(shù)據(jù)冗余。

2、選擇數(shù)據(jù)類型優(yōu)先級(jí) int > date,time > enum,char>varchar > blob,選擇數(shù)據(jù)類型時(shí),可以考慮替換,如ip地址可以用ip2long()函數(shù)轉(zhuǎn)換為unsign int型來(lái)進(jìn)行存儲(chǔ)。

3、對(duì)于char(n)類型,在數(shù)據(jù)完整的情況下盡量較小的的n值。

4、在建表時(shí)用partition命令對(duì)單個(gè)表分區(qū)可以大大提升查詢效率,MySQL支持RANGE,LIST,HASH,KEY分區(qū)類型,其中以RANGE最為常用,分區(qū)方式為:

CREATE TABLE tablename{
}ENGINE innodb/myisam CHARSET utf8 //選擇數(shù)據(jù)庫(kù)引擎和編碼
PARTITION BY RANGE/LIST(column),//按范圍和預(yù)定義列表進(jìn)行分區(qū)
PARTITION partname VALUES LESS THAN /IN(n),//命名分區(qū)并詳細(xì)限定分區(qū)的范圍

5、選擇數(shù)據(jù)庫(kù)引擎時(shí)要注意innodb 和 myisam的區(qū)別

存儲(chǔ)結(jié)構(gòu):MyISAM在磁盤上存儲(chǔ)成三個(gè)文件。而InnoDB所有的表都保存在同一個(gè)數(shù)據(jù)文件中,一般為2GB
事務(wù)支持:MyISAM不提供事務(wù)支持。InnoDB提供事務(wù)支持事務(wù)。
表鎖差異:MyISAM只支持表級(jí)鎖。InnoDB支持事務(wù)和行級(jí)鎖。
全文索引:MyISAM支持 FULLTEXT類型的全文索引(不適用中文,所以要用sphinx全文索引引擎)。InnoDB不支持。
表的具體行數(shù):MyISAM保存有表的總行數(shù),查詢count(*)很快。InnoDB沒(méi)有保存表的總行數(shù),需要重新計(jì)算。
外鍵:MyISAM不支持。InnoDB支持

索引方面優(yōu)化

1、innodb是聚簇索引,存儲(chǔ)索引時(shí)必須有主鍵,如果沒(méi)有指定,引擎會(huì)自動(dòng)生成一個(gè)隱藏的主鍵,生成一個(gè)主索引,索引內(nèi)存放的是主鍵的物理地址,數(shù)據(jù)靠主鍵存放,每次使用索引時(shí)要先找到主索引,然后找到主索引下的數(shù)據(jù)。

優(yōu)點(diǎn)通過(guò)主鍵查找特別快,缺點(diǎn)是次級(jí)索引會(huì)變慢,因?yàn)樾枰韧ㄟ^(guò)次級(jí)索引(次級(jí)索引里是主索引的位置。)找到主索引,然后通過(guò)主索引找數(shù)據(jù)。并且如果主鍵無(wú)規(guī)律,插入新值時(shí)需要移動(dòng)較多數(shù)據(jù)塊,會(huì)影響效率,所以要盡量使用有規(guī)律遞增的int型做主鍵。還有因?yàn)閿?shù)據(jù)緊跟著主鍵放,所以如果數(shù)據(jù)中有數(shù)據(jù)量特別大的列(text/blob),innodb查詢時(shí)會(huì)跳過(guò)很多數(shù)據(jù)塊,也會(huì)導(dǎo)致慢。

2、myisam的索引各個(gè)索引都相同統(tǒng)一指向磁盤上各個(gè)行的地址,都是輕量級(jí)的指針數(shù)據(jù)。缺點(diǎn)是各個(gè)索引的建立不是通過(guò)主鍵,查詢沒(méi)有聚簇索引查找主鍵快。但其因?yàn)榇鎯?chǔ)的是地址,所以在插入新值時(shí)比較方面移動(dòng)改變。

3、進(jìn)行多條件查詢時(shí),對(duì)多條件分別建立索引時(shí),執(zhí)行sql查詢時(shí),MySQL只會(huì)選擇一個(gè)最貼近的索引來(lái)使用,所以如果需要多條件查詢,要建立聯(lián)合索引,即使會(huì)造成數(shù)據(jù)冗余。

【網(wǎng)站聲明】本站除付費(fèi)源碼經(jīng)過(guò)測(cè)試外,其他素材未做測(cè)試,不保證完整性,網(wǎng)站上部分源碼僅限學(xué)習(xí)交流,請(qǐng)勿用于商業(yè)用途。如損害你的權(quán)益請(qǐng)聯(lián)系客服QQ:2655101040 給予處理,謝謝支持。

相關(guān)文檔推薦

這篇文章主要介紹了PHP有序表查找之插值查找算法,簡(jiǎn)單分析了插值查找算法的概念、原理并結(jié)合實(shí)例形式分析了php實(shí)現(xiàn)針對(duì)有序表插值查找的相關(guān)操作技巧,需要的朋友可以參考下
下面小編就為大家分享一篇ThinkPHP整合datatables實(shí)現(xiàn)服務(wù)端分頁(yè)的示例代碼,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
下面小編就為大家分享一篇PHP實(shí)現(xiàn)APP微信支付的實(shí)例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
這篇文章主要介紹了PHP實(shí)現(xiàn)的多維數(shù)組排序算法,結(jié)合實(shí)例形式對(duì)比分析了php針對(duì)多維數(shù)組及帶有鍵名的多維數(shù)組進(jìn)行排序相關(guān)操作技巧與注意事項(xiàng),需要的朋友可以參考下
這篇文章主要為大家詳細(xì)介紹了php結(jié)合ajaxuploadfile實(shí)現(xiàn)無(wú)刷新文件上傳功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
本篇文章給大家詳細(xì)介紹了PHP開(kāi)發(fā)接口使用RSA進(jìn)行加密解密方法,對(duì)此有興趣的朋友可以學(xué)習(xí)下。
主站蜘蛛池模板: 成人av在线看 | 在线日韩一区 | 中文一区二区 | 五月天婷婷激情网 | 永久免费精品视频 | 国产欧美精品 | 亚洲精品一区二区三区在线观看 | 草草视频在线 | 天天干天天操天天爽 | 国产91在线看 | 精品国产欧美一区二区三区成人 | 久久精品免费看 | 欧美午夜精品一区二区 | 久久久久久一区 | av影院在线| 亚洲激情中文字幕 | 精品一二三 | 国产欧美精品 | 激情91 | 欧美国产日韩精品 | 国产精品久久久久久中文字 | 成人午夜视频在线观看 | 成人三级视频 | 日韩欧美精品 | 在线观看黄色片 | 久久九九精品 | 久久艹精品 | 欧美精产国品一二三区 | 一级黄色免费看 | a级片免费 | 久久在线 | 免费av一区二区 | 亚洲最大av网站 | 亚洲国产精品久久久 | 国产精品欧美一区二区 | 91精品看片 | 青青在线 | 国产日韩精品视频 | 日韩在线专区 | 性大毛片视频 | 国产视频成人 |