<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
        主站蜘蛛池模板: 亚洲AV区无码字幕中文色| 91精品免费在线观看| 白白国产永久免费视频| 亚洲视频在线视频| 国产高清对白在线观看免费91| 99re热免费精品视频观看| 亚洲自偷自拍另类12p| 抽搐一进一出gif免费视频| 免费h成人黄漫画嘿咻破解版| 中日韩亚洲人成无码网站| 91高清免费国产自产| 蜜芽亚洲av无码精品色午夜| 成年免费a级毛片免费看无码| 免费一级毛片不卡在线播放| 色偷偷尼玛图亚洲综合| 日本不卡免费新一二三区| 亚洲午夜在线播放| 曰批全过程免费视频在线观看| 亚洲精品无码久久久久久久| 久久午夜伦鲁片免费无码| 亚洲AV成人一区二区三区AV| 免费国产成人α片| 亚洲VA中文字幕无码毛片| 99在线免费视频| 亚洲国产综合无码一区| 很黄很污的网站免费| 亚洲香蕉成人AV网站在线观看| 福利免费在线观看| 亚洲精品~无码抽插| 最好看的中文字幕2019免费| 亚洲电影唐人社一区二区| 最近高清中文字幕无吗免费看| 亚洲人成免费电影| 午夜免费福利影院| 美女黄色毛片免费看| 国产gv天堂亚洲国产gv刚刚碰| 华人在线精品免费观看| 亚洲av午夜精品无码专区| 日本不卡视频免费| 国产日韩久久免费影院| 久久av无码专区亚洲av桃花岛|