国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

mysql分表的詳細設計與應用_MySQL

來源:懂視網 責編:小采 時間:2020-11-09 18:34:33
文檔

mysql分表的詳細設計與應用_MySQL

mysql分表的詳細設計與應用_MySQL:bitsCN.com mysql分表的詳細設計與應用 一般來說,當我們的數據庫的數據超過了100w記錄的時候就應該考慮分表或者分區了,這次我來詳細說說分表的一些方法。目前我所知道的方法都是MYISAM的,INNODB如何做分表并且保留事務和外鍵,我還不是很了解。 首先,我
推薦度:
導讀mysql分表的詳細設計與應用_MySQL:bitsCN.com mysql分表的詳細設計與應用 一般來說,當我們的數據庫的數據超過了100w記錄的時候就應該考慮分表或者分區了,這次我來詳細說說分表的一些方法。目前我所知道的方法都是MYISAM的,INNODB如何做分表并且保留事務和外鍵,我還不是很了解。 首先,我

bitsCN.com

mysql分表的詳細設計與應用

一般來說,當我們的數據庫的數據超過了100w記錄的時候就應該考慮分表或者分區了,這次我來詳細說說分表的一些方法。目前我所知道的方法都是MYISAM的,INNODB如何做分表并且保留事務和外鍵,我還不是很了解。

首先,我們需要想好到底分多少個表,前提當然是滿足應用。這里我使用了一個比較簡單的分表方法,就是根據自增id的尾數來分,也就是說分0-9一共10個表,其取值也很好做,就是對10進行取模。另外,還可以根據某一字段的md5值取其中幾位進行分表,這樣的話,可以分的表就很多了。

好了,先來創建表吧,代碼如下

CREATE TABLE `test`.`article_0` (

`id` BIGINT( 20 ) NOT NULL ,

`subject` VARCHAR( 200 ) NOT NULL ,

`content` TEXT NOT NULL ,

PRIMARY KEY ( `id` )

) ENGINE = MYISAM CHARACTER SET utf8 COLLATE utf8_general_ci

CREATE TABLE `test`.`article_1` (

`id` BIGINT( 20 ) NOT NULL ,

`subject` VARCHAR( 200 ) NOT NULL ,

`content` TEXT NOT NULL ,

PRIMARY KEY ( `id` )

) ENGINE = MYISAM CHARACTER SET utf8 COLLATE utf8_general_ci

CREATE TABLE `test`.`article_2` (

`id` BIGINT( 20 ) NOT NULL ,

`subject` VARCHAR( 200 ) NOT NULL ,

`content` TEXT NOT NULL ,

PRIMARY KEY ( `id` )

) ENGINE = MYISAM CHARACTER SET utf8 COLLATE utf8_general_ci

CREATE TABLE `test`.`article_3` (

`id` BIGINT( 20 ) NOT NULL ,

`subject` VARCHAR( 200 ) NOT NULL ,

`content` TEXT NOT NULL ,

PRIMARY KEY ( `id` )

) ENGINE = MYISAM CHARACTER SET utf8 COLLATE utf8_general_ci

CREATE TABLE `test`.`article_4` (

`id` BIGINT( 20 ) NOT NULL ,

`subject` VARCHAR( 200 ) NOT NULL ,

`content` TEXT NOT NULL ,

PRIMARY KEY ( `id` )

) ENGINE = MYISAM CHARACTER SET utf8 COLLATE utf8_general_ci

CREATE TABLE `test`.`article_5` (

`id` BIGINT( 20 ) NOT NULL ,

`subject` VARCHAR( 200 ) NOT NULL ,

`content` TEXT NOT NULL ,

PRIMARY KEY ( `id` )

) ENGINE = MYISAM CHARACTER SET utf8 COLLATE utf8_general_ci

CREATE TABLE `test`.`article_6` (

`id` BIGINT( 20 ) NOT NULL ,

`subject` VARCHAR( 200 ) NOT NULL ,

`content` TEXT NOT NULL ,

PRIMARY KEY ( `id` )

) ENGINE = MYISAM CHARACTER SET utf8 COLLATE utf8_general_ci

CREATE TABLE `test`.`article_7` (

`id` BIGINT( 20 ) NOT NULL ,

`subject` VARCHAR( 200 ) NOT NULL ,

`content` TEXT NOT NULL ,

PRIMARY KEY ( `id` )

) ENGINE = MYISAM CHARACTER SET utf8 COLLATE utf8_general_ci

CREATE TABLE `test`.`article_8` (

`id` BIGINT( 20 ) NOT NULL ,

`subject` VARCHAR( 200 ) NOT NULL ,

`content` TEXT NOT NULL ,

PRIMARY KEY ( `id` )

) ENGINE = MYISAM CHARACTER SET utf8 COLLATE utf8_general_ci

CREATE TABLE `test`.`article_9` (

`id` BIGINT( 20 ) NOT NULL ,

`subject` VARCHAR( 200 ) NOT NULL ,

`content` TEXT NOT NULL ,

PRIMARY KEY ( `id` )

) ENGINE = MYISAM CHARACTER SET utf8 COLLATE utf8_general_ci

好了10個表創建完畢了,需要注意的是,這里的id不能設為自增,而且所有的表結構必須一致,包括結構,類型,長度,字段的順序都必須一致那么對于這個id如何取得呢?后面我會詳細說明。現在,我們需要一個合并表,用于查詢,創建合并表的代碼如下

CREATE TABLE `test`.`article` (

`id` BIGINT( 20 ) NOT NULL ,

`subject` VARCHAR( 200 ) NOT NULL ,

`content` TEXT NOT NULL ,

PRIMARY KEY ( `id` )

) ENGINE=MRG_MyISAM DEFAULT CHARSET=utf8 INSERT_METHOD=0 UNION=(`article_0`,`article_1`,`article_2`,`article_3`,`article_4`,`article_5`,`article_6`,`article_7`,`article_8`,`article_9`);

注意,合并表也必須和前面的表有相同的結構,類型,長度,包括字段的順序都必須一致這里的INSERT_METHOD=0表示不允許對本表進行insert操作。好了,當需要查詢的時候,我們可以只對article這個表進行操作就可以了,也就是說這個表僅僅只能進行select操作

那么對于插入也就是insert操作應該如何來搞呢,首先就是獲取唯一的id了,這里就還需要一個表來專門創建id,代碼如下

CREATE TABLE `test`.`create_id` (

`id` BIGINT( 20 ) NOT NULL AUTO_INCREMENT PRIMARY KEY

) ENGINE = MYISAM

也就是說,當我們需要插入數據的時候,必須由這個表來產生id值,我的php代碼的方法如下

function get_AI_ID() {

$sql = "insert into create_id (id) values('')";

$this->db->query($sql);

return $this->db->insertID();

}

好了,現在假設我們要插入一條數據了,應該怎么操作呢?還是繼續看代碼吧

function new_Article() {

$id = $this->get_AI_ID();

$table_name = $this->get_Table_Name($id);

$sql = "insert into {$table_name} (id,subject,content) values('{$id}','測試標題','測試內容')";

$this->db->query($sql);

}

/**

* 用于根據id獲取表名

*/

function get_Table_Name($id) {

return 'article_'.intval($id)%10;

}

其實很簡單的,對吧,就是先獲取id,然后根據id獲取應該插入到哪個表,然后就很簡單了。

對于update的操作我想應該不需要再說了吧,無非是有了id,然后獲取表名,然后進行update操作就好了。

bitsCN.com

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

mysql分表的詳細設計與應用_MySQL

mysql分表的詳細設計與應用_MySQL:bitsCN.com mysql分表的詳細設計與應用 一般來說,當我們的數據庫的數據超過了100w記錄的時候就應該考慮分表或者分區了,這次我來詳細說說分表的一些方法。目前我所知道的方法都是MYISAM的,INNODB如何做分表并且保留事務和外鍵,我還不是很了解。 首先,我
推薦度:
標簽: 記錄 如何 設計
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 国产全黄a一级毛片视频 | 久草伦理 | 水蜜桃网站 | 伊人久久精品久久亚洲一区 | 久久亚洲精品国产精品婷婷 | 又大又硬又爽 | 国产精品免费视频播放 | 99精品国产成人一区二区 | 日韩欧美制服 | 欧美一区二区在线播放 | 亚洲综合视频 | 久久精品一 | 国产日产欧美精品一区二区三区 | 草b视频在线观看 | 黑人操穴 | 欧美综合国产精品日韩一 | 欧美精品久久久久久久久大尺度 | 久久精品国产亚洲aa | 亚洲欧洲日本在线观看 | 亚洲 欧美 自拍 另类 欧美 | 欧美一区二区三区网站 | 国产精品久久久久激情影院 | 欧美日韩高清一区 | 快播电影网日韩新片 | 亚洲欧美日韩精品高清 | 久久91精品国产91久久 | 黄色a级毛片 | 久久久久国产成人精品亚洲午夜 | 日本免费一区尤物 | 日本1区2区3区电 | 国产一区二区三区高清 | 国产欧美在线观看精品一区二区 | 欧美精品一区二区三区视频 | 欧美专区亚洲 | 国产激情在线观看 | 国产精选在线观看 | 欧美三级一区 | 五月婷婷在线视频 | 欧美成人a级在线视频 | 久久精品无码一区二区日韩av | 亚洲va欧美ⅴa国产va影院 |