日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

MYSQL性能优化分享(分库分表)

發(fā)布時(shí)間:2023/12/4 数据库 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MYSQL性能优化分享(分库分表) 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

1、分庫分表?

很明顯,一個(gè)主表(也就是很重要的表,例如用戶表)無限制的增長勢(shì)必嚴(yán)重影響性能,分庫與分表是一個(gè)很不錯(cuò)的解決途徑,也就是性能優(yōu)化途徑,現(xiàn)在的案例是我們有一個(gè)1000多萬條記錄的用戶表members,查詢起來非常之慢,同事的做法是將其散列到100個(gè)表中,分別從members0到members99,然后根據(jù)mid分發(fā)記錄到這些表中,牛逼的代碼大概是這樣子:?

復(fù)制代碼

<?php? for($i=0;$i<?100;?$i++?){? //echo?"CREATE?TABLE?db2.members{$i}?LIKE?db1.members<br>";? echo?"INSERT?INTO?members{$i}?SELECT?*?FROM?members?WHERE?mid%100={$i}<br>";? }? ?>



2、不停機(jī)修改mysql表結(jié)構(gòu)?

同樣還是members表,前期設(shè)計(jì)的表結(jié)構(gòu)不盡合理,隨著數(shù)據(jù)庫不斷運(yùn)行,其冗余數(shù)據(jù)也是增長巨大,同事使用了下面的方法來處理:?

先創(chuàng)建一個(gè)臨時(shí)表:?
/*創(chuàng)建臨時(shí)表*/?
CREATE TABLE members_tmp LIKE members?

然后修改members_tmp的表結(jié)構(gòu)為新結(jié)構(gòu),接著使用上面那個(gè)for循環(huán)來導(dǎo)出數(shù)據(jù),因?yàn)?000萬的數(shù)據(jù)一次性導(dǎo)出是不對(duì)的,mid是主鍵,一個(gè)區(qū)間一個(gè)區(qū)間的導(dǎo),基本是一次導(dǎo)出5萬條吧,這里略去了?
接著重命名將新表替換上去:?

/*這是個(gè)頗為經(jīng)典的語句哈*/?
RENAME TABLE members TO members_bak,members_tmp TO members;?

就是這樣,基本可以做到無損失,無需停機(jī)更新表結(jié)構(gòu),但實(shí)際上RENAME期間表是被鎖死的,所以選擇在線少的時(shí)候操作是一個(gè)技巧。經(jīng)過這個(gè)操作,使得原先8G多的表,一下子變成了2G多?

另外還講到了mysql中float字段類型的時(shí)候出現(xiàn)的詭異現(xiàn)象,就是在pma中看到的數(shù)字根本不能作為條件來查詢.感謝zj同學(xué)的新鮮分享。

您可能感興趣的文章:

  • MYSQL IN 與 EXISTS 的優(yōu)化示例介紹

  • 實(shí)現(xiàn)MySQL定時(shí)批量檢查表repair和優(yōu)化表optimize table的shell腳本

  • MySQL性能優(yōu)化之路---修改配置文件my.cnf

  • MySQL5.6基本優(yōu)化配置

  • 淺析Mysql Join語法以及性能優(yōu)化

  • MySQL優(yōu)化必須調(diào)整的10項(xiàng)配置

  • mysql數(shù)據(jù)庫優(yōu)化總結(jié)(心得)

  • MySQL Order by 語句用法與優(yōu)化詳解

  • mysql嵌套查詢和聯(lián)表查詢優(yōu)化方法

  • MySQL 百萬級(jí)分頁優(yōu)化(Mysql千萬級(jí)快速分頁)

  • MySQL配置文件my.cnf中文詳解附mysql性能優(yōu)化方法分享

  • mysql千萬級(jí)數(shù)據(jù)大表該如何優(yōu)化?

  • mysql limit分頁優(yōu)化方法分享

  • mysql優(yōu)化配置參數(shù)

  • MySQL 性能優(yōu)化的最佳20多條經(jīng)驗(yàn)分享

  • MySQL數(shù)據(jù)庫優(yōu)化詳解


轉(zhuǎn)載于:https://blog.51cto.com/fccwcom/1583452

總結(jié)

以上是生活随笔為你收集整理的MYSQL性能优化分享(分库分表)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。