1盡量使用數(shù)字型字段,若只含數(shù)值信息的字段盡量不要設(shè)計(jì)為字符型,這會(huì)降低查詢和連接的性能,并會(huì)增加存儲(chǔ)開(kāi)銷(xiāo)。這是因?yàn)橐嬖谔幚聿樵兒瓦B接時(shí)會(huì) 逐個(gè)比較字符串中每一個(gè)字符,而對(duì)于數(shù)字型而言只需要比較一次就夠了。
成都創(chuàng)新互聯(lián)網(wǎng)站建設(shè)服務(wù)商,為中小企業(yè)提供成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站建設(shè)服務(wù),網(wǎng)站設(shè)計(jì),網(wǎng)站運(yùn)營(yíng)等一站式綜合服務(wù)型公司,專業(yè)打造企業(yè)形象網(wǎng)站,讓您在眾多競(jìng)爭(zhēng)對(duì)手中脫穎而出成都創(chuàng)新互聯(lián)。
使用多個(gè) MySQL 服務(wù)器(復(fù)制或者 Percona XtraDB Cluster)可以讓我們?cè)谀承┎樵兩系玫筋~外的性能提升。你也可以使用 Spark 的緩存功能來(lái)緩存整個(gè) MySQL 查詢結(jié)果表。
數(shù)據(jù)庫(kù)大?。弘S著數(shù)據(jù)庫(kù)大小的增加,查詢開(kāi)始慢的可能性也會(huì)增加。 數(shù)據(jù)庫(kù)結(jié)構(gòu):如果數(shù)據(jù)庫(kù)結(jié)構(gòu)復(fù)雜,包含多個(gè)表、索引、視圖等,查詢開(kāi)始慢的可能性也會(huì)增加。
避免使用!=或<>、IS NULL或IS NOT NULL、IN ,NOT IN等這樣的操作符。優(yōu)化SQL語(yǔ)句(讓SQL語(yǔ)句更合理一些)。優(yōu)化數(shù)據(jù)庫(kù)字段類(lèi)型。(能用其他的盡量不要用VCHAR)建立儲(chǔ)存過(guò)程。
sex 加上索引。比如 SELECT * FROM `goods` WHERE `sex` = 1 這樣算比較高效的查詢到了所有男裝了。因?yàn)樗谐绦蛟谔幚頂?shù)字類(lèi)型普遍速度是最快的,而 tinyint 為 int類(lèi)型中的最小,速度也就更快了。
1、優(yōu)化SQL語(yǔ)句(讓SQL語(yǔ)句更合理一些)。優(yōu)化數(shù)據(jù)庫(kù)字段類(lèi)型。(能用其他的盡量不要用VCHAR)建立儲(chǔ)存過(guò)程。
2、找到你mysql的安裝目錄,打開(kāi)my.ini,如果是Linux服務(wù)器,那就是my.conf;然后在[mysqld]選項(xiàng)下面添加:skip-name-resolve 這個(gè)選項(xiàng)的意思是:禁用DNS解析,連接速度會(huì)快很多。
3、如果數(shù)據(jù)庫(kù)服務(wù)器配置不足,例如內(nèi)存、CPU等資源不足,查詢開(kāi)始慢的可能性也會(huì)增加。一般來(lái)說(shuō),當(dāng)數(shù)據(jù)庫(kù)表的數(shù)據(jù)量達(dá)到數(shù)百萬(wàn)條或以上時(shí),查詢開(kāi)始慢的可能性就會(huì)增加。但具體情況還需要根據(jù)實(shí)際情況進(jìn)行評(píng)估。
4、\ 對(duì)于 information_schema 中的元數(shù)據(jù)表,執(zhí)行計(jì)劃不能提供有效信息。\ 通過(guò)查看 MySQL 改寫(xiě)后的 SQL,我們猜測(cè)了優(yōu)化器發(fā)生了誤判。\ 我們?cè)黾恿?hint,指導(dǎo) MySQL 正確進(jìn)行優(yōu)化判斷。
1、PHP程序就那么丁點(diǎn)東西,無(wú)必要跟DB分開(kāi),除非你的網(wǎng)站數(shù)據(jù)有像FB或者谷歌那樣。你把程序和DB分開(kāi)裝,那就是要遠(yuǎn)程連接了,這樣的話,能比本地連接效率高嗎?你說(shuō)你想把程序放在國(guó)外,國(guó)外的主機(jī)與國(guó)內(nèi)的訪問(wèn)速度本來(lái)就慢。
2、1:可能是數(shù)據(jù)庫(kù)機(jī)碎片過(guò)多。也也可能是文件索引沒(méi)生成優(yōu)化好。嘗試壓縮與修復(fù)數(shù)據(jù)凌亂內(nèi)容之后在從新建立索引,在發(fā)送到SQL機(jī)(不知道你使用的是直接通訊發(fā)布還是遠(yuǎn)程發(fā)布,不可以直接那就找到數(shù)據(jù)手動(dòng)拷貝。
3、在此前提下,可以這么設(shè)計(jì)解決方案。所以你問(wèn)題里“數(shù)據(jù)仍然需要同步”這個(gè)理解是不對(duì)的。事實(shí)上,正是由于允許用戶讀到幾秒鐘甚至幾分鐘前的數(shù)據(jù),才可以使用讀寫(xiě)分離的。數(shù)據(jù)庫(kù)里面concurrency control是最復(fù)雜的組件之一。