一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數據庫技術|

服務器之家 - 數據庫 - Mysql - MYSQL性能優化分享(分庫分表)

MYSQL性能優化分享(分庫分表)

2019-11-29 17:30MYSQL教程網 Mysql

MYSQL性能優化之分庫分表與不停機修改mysql表結構,需要的朋友可以參考下

1、分庫分表 

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

復制代碼代碼如下:


<?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、不停機修改mysql表結構 

同樣還是members表,前期設計的表結構不盡合理,隨著數據庫不斷運行,其冗余數據也是增長巨大,同事使用了下面的方法來處理: 

先創建一個臨時表: 
/*創建臨時表*/ 
CREATE TABLE members_tmp LIKE members 

然后修改members_tmp的表結構為新結構,接著使用上面那個for循環來導出數據,因為1000萬的數據一次性導出是不對的,mid是主鍵,一個區間一個區間的導,基本是一次導出5萬條吧,這里略去了 
接著重命名將新表替換上去: 

/*這是個頗為經典的語句哈*/ 
RENAME TABLE members TO members_bak,members_tmp TO members; 

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

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

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 男人影院天堂网址 | 欧美日韩国产手机在线观看视频 | 亚洲人成网站在线观看妞妞网 | 国产视频一区 | 欧美gayxxxx| 俄罗斯海滩厕所偷窥 | xx18美女美国| 青青草国产免费久久久91 | 国产在线麻豆波多野结衣 | 国产精品夜色视频一级区 | 欧美一区二区三区精品国产 | 青草娱乐极品免费视频 | 日产精品一卡2卡三卡4乱码久久 | 国产精品福利在线观看免费不卡 | 国产日韩欧美综合一区二区三区 | 麻豆在线传煤 | 欧美成人免费观看国产 | 国产麻豆91网在线看 | 日韩欧美国内 | 国产成人亚洲影视在线 | 国产欧美日韩不卡 | 日本黄a三级三级三级 | 色综合久久中文字幕综合网 | 陈峰姚瑶全集小说无删节 | 午夜影院网站 | 999久久久免费精品国产牛牛 | 波多野结衣之高校教师 | 亚洲国产精品无圣光一区二区 | 60岁妇女毛片免费观看 | 99精品影院 | 国产黑丝一区 | 女bbbxxx毛片视频 | 疯狂激吻添下边小说 | 日韩av.com | 日本中文字幕一区二区高清在线 | 精品无码人妻一区二区免费AV | 亚洲视频中文 | 91大片淫黄大片在线天堂 | 天天白天天谢天天啦 | 亚洲国产日韩欧美一区二区三区 | 久久视热频国产这里只有精品23 |