1億條數(shù)據(jù)如何分表100張到Mysql數(shù)據(jù)庫中(PHP)
下面通過創(chuàng)建100張表來演示下1億條數(shù)據(jù)的分表過程,具體請(qǐng)看下文代碼。
當(dāng)數(shù)據(jù)量猛增的時(shí)候,大家都會(huì)選擇庫表散列等等方式去優(yōu)化數(shù)據(jù)讀寫速度。筆者做了一個(gè)簡(jiǎn)單的嘗試,1億條數(shù)據(jù),分100張表。具體實(shí)現(xiàn)過程如下:
首先創(chuàng)建100張表:
$i=0; while($i<=99){ echo "$newNumber \r\n"; $sql="CREATE TABLE `code_".$i."` ( `full_code` char(10) NOT NULL, `create_time` int(10) unsigned NOT NULL, PRIMARY KEY (`full_code`), ) ENGINE=MyISAM DEFAULT CHARSET=utf8"; mysql_query($sql); $i++;
下面說一下我的分表規(guī)則,full_code作為主鍵,我們對(duì)full_code做hash
函數(shù)如下:
$table_name=get_hash_table('code',$full_code); function get_hash_table($table,$code,$s=100){ $hash = sprintf("%u", crc32($code)); echo $hash; $hash1 = intval(fmod($hash, $s)); return $table."_".$hash1; }
這樣插入數(shù)據(jù)前通過get_hash_table獲取數(shù)據(jù)存放的表名。
最后我們使用merge存儲(chǔ)引擎來實(shí)現(xiàn)一張完整的code表
CREATE TABLE IF NOT EXISTS `code` ( `full_code` char(10) NOT NULL, `create_time` int(10) unsigned NOT NULL, INDEX(full_code) ) TYPE=MERGE UNION=(code_0,code_1,code_2.......) INSERT_METHOD=LAST ;
這樣我們通過select * from code就可以得到所有的full_code數(shù)據(jù)了。
以上介紹就是本文的全部?jī)?nèi)容,希望對(duì)大家有所幫助。
- mysql數(shù)據(jù)庫分表分庫的策略
- MySQL 5.7雙主同步部分表的實(shí)現(xiàn)過程詳解
- MyBatis實(shí)現(xiàn)Mysql數(shù)據(jù)庫分庫分表操作和總結(jié)(推薦)
- 什么是分表和分區(qū) MySql數(shù)據(jù)庫分區(qū)和分表方法
- Mysql數(shù)據(jù)庫性能優(yōu)化三(分表、增量備份、還原)
- MYSQL數(shù)據(jù)庫數(shù)據(jù)拆分之分庫分表總結(jié)
- MySQL分表自增ID問題的解決方法
- PHP操作mysql數(shù)據(jù)庫分表的方法
- Mysql數(shù)據(jù)庫分庫和分表方式(常用)
- php實(shí)現(xiàn)mysql數(shù)據(jù)庫分表分段備份
- mysql分表和分區(qū)的區(qū)別淺析
- mysql的3種分表方案
- MySQL分表實(shí)現(xiàn)上百萬上千萬記錄分布存儲(chǔ)的批量查詢?cè)O(shè)計(jì)模式詳解
- MYSQL性能優(yōu)化分享(分庫分表)
- 使用MySQL的LAST_INSERT_ID來確定各分表的唯一ID值
- MySQL動(dòng)態(tài)創(chuàng)建表,數(shù)據(jù)分表的存儲(chǔ)過程
- MySQL 分表優(yōu)化試驗(yàn)代碼
- mysql分表分庫的應(yīng)用場(chǎng)景和設(shè)計(jì)方式
相關(guān)文章
php使用str_shuffle()函數(shù)生成隨機(jī)字符串的方法分析
這篇文章主要介紹了php使用str_shuffle()函數(shù)生成隨機(jī)字符串的方法,結(jié)合兩個(gè)簡(jiǎn)單實(shí)例形式分析了基于str_shuffle()函數(shù)的隨機(jī)打亂字符串順序功能實(shí)現(xiàn)隨機(jī)字符串的相關(guān)操作技巧,需要的朋友可以參考下2017-02-02解析數(shù)組非數(shù)字鍵名引號(hào)的必要性
以下是對(duì)數(shù)組非數(shù)字鍵名引號(hào)的必要性進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過來參考下2013-08-08PHP 創(chuàng)建標(biāo)簽云函數(shù)代碼
PHP創(chuàng)建標(biāo)簽云函數(shù)代碼,使用此函數(shù)創(chuàng)建標(biāo)簽云。2010-05-05如何在smarty中增加類似foreach的功能自動(dòng)加載數(shù)據(jù)
本篇文章是對(duì)在smarty中增加類似foreach的功能自動(dòng)加載數(shù)據(jù)進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06PHP擴(kuò)展程序?qū)崿F(xiàn)守護(hù)進(jìn)程
守護(hù)進(jìn)程就是在后臺(tái)一直運(yùn)行的進(jìn)程。比如我們啟動(dòng)的httpd,mysqld等進(jìn)程都是常駐內(nèi)存內(nèi)運(yùn)行的程序。,下面我們就來探討下,如何使用php來實(shí)現(xiàn)守護(hù)進(jìn)程2015-04-04PHP call_user_func和call_user_func_array函數(shù)的簡(jiǎn)單理解與應(yīng)用分析
這篇文章主要介紹了PHP call_user_func和call_user_func_array函數(shù)的簡(jiǎn)單理解與應(yīng)用,結(jié)合實(shí)例形式分析了PHP call_user_func和call_user_func_array函數(shù)的基本功能、用法及操作注意事項(xiàng),需要的朋友可以參考下2019-11-11php基礎(chǔ)知識(shí):類與對(duì)象(5) static
php基礎(chǔ)知識(shí):類與對(duì)象(5) static...2006-12-12jq的get傳參數(shù)在utf-8中亂碼問題的解決php版
在php下用jquery傳參出現(xiàn)亂碼的解決方法2008-07-07