來自http://www.hmoore.net/digest/mysqlsummary/132848
### 一,分庫
#### 1.1 按照功能分庫
按照功能進行分庫。常見的分成6大庫:
1 用戶類庫:用于保存了用戶的相關信息。例如:db_user,db_system,db_company等。
2 業務類庫:用于保存主要業務的信息。比如主要業務是笑話,用這個庫保存笑話業務。例如:db_joke,db_temp_joke等。
3 內存類庫:主要用Mysql的內存引擎。前臺的數據從內存庫中查找,速度快。例如:heap。
4 圖片類庫:主要保存圖片的索引以及關聯。例如:db_img_index,db_img_res。
5 日志類庫:記錄點擊,刷新,登錄等日志信息。例如:db_log_click,db_log_fresh,db_log_login。
6 統計類庫:對業務的統計,比如點擊量,刷新量等等。例如db_stat。
#### 1.2 安裝城市站分庫
如果業務遍布全國,在按照功能分庫庫,每一個城市復制一份一模一樣的庫,只是庫后綴都是城市名稱。比如db_log_click_bj,db_log_click_tj,db_log_click_sh;
### 二,分表
#### 2.1 水平分割。解決表行數過大問題
2.1.1 按照用戶或業務的編號分表
對與用戶或業務可以按照編號%n,進行分成n表。
例如:笑話表。
tb_joke_01,tb_joke_02,tb_joke_03,tb_joke_04…
#### 2.1.2 按照日期分表
對于日志或統計類等的表。可以按照年,月,日,周分表。
例如 點擊量統計。
tb_click_stat_201601,tb_click_stat_201602,tb_click_stat_201603
#### 2.2 垂直分割。解決列過長問題。
1)經常組合查詢的列放在一張表中。常用字段的表可以考慮用Memory引擎。
2)把不常用的字段單獨放在一張表。
3)把text,blob等大字段拆分出來放在附表中。
### 三,Mysql數據庫常用架構
核心:一主多從,讀寫分離。

- 數據庫
- CAP定理
- 關系模型
- 關系數據庫
- NoSQL
- ODBC
- JDBC
- ODBC、JDBC和四種驅動類型
- mysql
- 安裝與配置
- CentOS 7 安裝 MySQL
- 優化
- 比較全面的MySQL優化參考
- 1、硬件層相關優化
- 1.1、CPU相關
- 1.2、磁盤I/O相關
- 2、系統層相關優化
- 2.1、文件系統層優化
- 2.2、其他內核參數優化
- 3、MySQL層相關優化
- 3.1、關于版本選擇
- 3.2、關于最重要的參數選項調整建議
- 3.3、關于Schema設計規范及SQL使用建議
- 3.4、其他建議
- 后記
- Mysql設計與優化專題
- ER圖,數據建模與數據字典
- 數據中設計中的范式與反范式
- 字段類型與合理的選擇字段類型
- 表的垂直拆分和水平拆分
- 詳解慢查詢
- mysql的最佳索引攻略
- 高手詳解SQL性能優化十條經驗
- 優化SQL查詢:如何寫出高性能SQL語句
- MySQL索引原理及慢查詢優化
- 數據庫SQL優化大總結之 百萬級數據庫優化方案
- 數據庫性能優化之SQL語句優化1
- 【重磅干貨】看了此文,Oracle SQL優化文章不必再看!
- MySQL 對于千萬級的大表要怎么優化?
- MySQL 數據庫設計總結
- MYSQL性能優化的最佳20+條經驗
- 數據操作
- 數據語句操作類型
- DCL
- 修改Mysql數據庫名的5種方法
- DML
- 連接
- 連接2
- DDL
- 數據類型
- 字符集
- 表引擎
- 索引
- MySQL理解索引、添加索引的原則
- mysql建索引的幾大原則
- 淺談mysql的索引設計原則以及常見索引的區別
- 常用工具簡介
- QA
- MySQL主機127.0.0.1與localhost區別總結
- 視圖(view)
- 觸發器
- 自定義函數和存儲過程的使用
- 事務(transaction)
- 范式與反范式
- 常用函數
- MySQL 數據類型 詳解
- Mysql數據庫常用分庫和分表方式
- 隔離級別
- 五分鐘搞清楚MySQL事務隔離級別
- mysql隔離級別及事務傳播
- 事務隔離級別和臟讀的快速入門
- 數據庫引擎中的隔離級別
- 事務隔離級別
- Innodb中的事務隔離級別和鎖的關系
- MySQL 四種事務隔離級的說明
- Innodb鎖機制:Next-Key Lock 淺談
- SQL函數和存儲過程的區別
- mongo
- MongoDB設置訪問權限、設置用戶
- redis
- ORM
- mybatis
- $ vs #
- mybatis深入理解(一)之 # 與 $ 區別以及 sql 預編譯
- 電商設計
- B2C電子商務系統研發——概述篇
- B2C電子商務系統研發——商品數據模型設計
- B2C電子商務系統研發——商品模塊E-R圖建模
- B2C電子商務系統研發——商品SKU分析和設計(一)
- B2C電子商務系統研發——商品SKU分析和設計(二)
- 數據庫命名規范--通用