<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答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
        主站蜘蛛池模板: 亚洲精品成人网久久久久久| 99久久综合国产精品免费| 国产99视频精品免费视频7| 亚洲乱码在线卡一卡二卡新区| 67194成手机免费观看| 亚洲美女视频网址| 久久九九兔免费精品6| 亚洲一区二区三区不卡在线播放| 亚洲一区二区免费视频| 亚洲高清一区二区三区| 国产精品久久久久影院免费| 美女免费视频一区二区三区| 亚洲一级特黄大片无码毛片| 久久国产美女免费观看精品 | 久久久久亚洲国产AV麻豆| 国产一级淫片a视频免费观看| 国产亚洲福利一区二区免费看 | 亚洲成a人片在线观看中文app| 亚洲视频在线观看免费视频| 成人亚洲国产va天堂| 国产国产人免费人成免费视频 | 日本视频免费高清一本18| baoyu116.永久免费视频| 亚洲gv白嫩小受在线观看| 青娱乐在线视频免费观看| 亚洲精品国产精品乱码不卞| 怡红院免费全部视频在线视频| 亚洲综合激情九月婷婷| 在线免费一区二区| 久久一区二区免费播放| 亚洲伊人久久精品| 可以免费观看的一级毛片| 国内少妇偷人精品视频免费| 亚洲AV无码成人专区| 亚洲av片一区二区三区| 羞羞视频免费观看| 久久亚洲精品无码| 99久在线国内在线播放免费观看| 亚洲色婷婷一区二区三区| 四虎最新永久免费视频| 丰满少妇作爱视频免费观看|