• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            woaidongmao

            文章均收錄自他人博客,但不喜標題前加-[轉貼],因其丑陋,見諒!~
            隨筆 - 1469, 文章 - 0, 評論 - 661, 引用 - 0
            數據加載中……

            MySQL分區的簡單實例

            mysql數據庫的分區
            mysql
            數據庫分區也叫mysql數據庫分表,即當一個表中數據庫非常大時,查詢速度非常慢影響效率,同時也增加了io的壓力,這樣我們就可以用分表的形式將一個表根據一定的規則將他分成多個表,主要的分表類型有range,list,hashkey,詳細說明可以參考mysql5.1以上版本參考手冊

            mysql分區支持主要在5.1以上版本,如果你的mysql5.1以上版本,查看是否支持分區的方式是:
            mysql> show variables like 'h%';
            +-------------------------+-----------------------+
            | Variable_name           | Value                 |
            +-------------------------+-----------------------+
            | have_community_features | YES                   |
            | have_compress           | YES                   |
            | have_crypt              | YES                   |
            | have_csv                | YES                   |
            | have_dynamic_loading    | YES                   |
            | have_geometry           | YES                   |
            | have_innodb             | NO                    |
            | have_ndbcluster         | NO                    |
            | have_openssl            | NO                    |
            | have_partitioning       | YES                   | -->>
            此項為yes說明支持表分區功能,如果為No則需要重新編譯
            | have_query_cache        | YES                   |
            | have_rtree_keys         | YES                   |
            | have_ssl                | NO                    |
            | have_symlink            | YES                   |
            | hostname                | localhost.localdomain |
            +-------------------------+-----------------------+
            15 rows in set (0.02 sec)

            如果不支持,則需要下載mysql5.1及以上版本,重新編譯安裝,這里以mysql-5.1.30.tar.gz來編譯安裝

            1.
            下載mysql-5.1.30.tar.gz源碼,
            2.
            解壓
                tar xvzf mysql-5.1.30.tar.gz
                cd mysql-5.1.30
                ./configure --prefix=/usr/local/mysql \
                --localstatedir=/data \
                --datadir=/data \
                --with-plugins=partition    //
            添加分區功能

                make && make install
                cd /usr/local/mysql/bin
                ./mysql_install_db
                ./mysqld_safe &
            3.
            安裝成功,則時mysql支持分區功能

            4.
            分區簡單實例,以range分區類型為例:
            create table users00 (
            uid int unsigned not null auto_increment primary key,
            name varchar(30) not null default "",
            email varchar(30) not null default ""
            )partition by range (uid)
            ( partition p0 values less than (10000) data directory = "/data00/" index directory = "/data00/",
            partition p1 values less than (20000) data directory = "/data00/" index directory = "/data00/",
            partition p2 values less than (30000) data directory = "/data00/" index directory = "/data00/",
            partition p3 values less than maxvalue data directory = "/data00/" index directory = "/data00/"
            );
            該表分區類型為range,分為4個區,uid0~10000p0區,10001~20000p1 ...
            查看users00表所在的數據目錄:
            ....
            -rw-rw---- 1 root root   8620 Nov 22 14:47 users00.frm
            -rw-rw---- 1 root root     32 Nov 22 14:47 users00.par
            lrwxrwxrwx 1 root root     24 Nov 22 14:47 users00#P#p0.MYD -> /data00/users00#P#p0.MYD
            lrwxrwxrwx 1 root root     24 Nov 22 14:47 users00#P#p0.MYI -> /data00/users00#P#p0.MYI
            lrwxrwxrwx 1 root root     24 Nov 22 14:39 users00#P#p1.MYD -> /data00/users00#P#p1.MYD
            lrwxrwxrwx 1 root root     24 Nov 22 14:39 users00#P#p1.MYI -> /data00/users00#P#p1.MYI
            lrwxrwxrwx 1 root root     24 Nov 22 14:39 users00#P#p2.MYD -> /data00/users00#P#p2.MYD
            lrwxrwxrwx 1 root root     24 Nov 22 14:39 users00#P#p2.MYI -> /data00/users00#P#p2.MYI
            lrwxrwxrwx 1 root root     24 Nov 22 14:39 users00#P#p3.MYD -> /data00/users00#P#p3.MYD
            lrwxrwxrwx 1 root root     24 Nov 22 14:39 users00#P#p3.MYI -> /data00/users00#P#p3.MYI
            ....

            此時表數據已經達到了物理分區,這樣可以減少同一目錄的IO,同時由單表的3w記錄下降到了單表1w的數據量,這樣查詢起來效率更高

            5.
            分區的修改和合并

            以下是將p0分區再分割成2分區s0,s1的例子:

            mysql> alter table users00 reorganize partition p0 into( partition s0 values less than (3999) data directory='/data00/' index directory='/data00/', partition s1 values less than (10000) data directory='/data00/' index directory='/data00/' );
            Query OK, 0 rows affected (0.03 sec)
            Records: 0  Duplicates: 0  Warnings: 0

            mysql>
            分割成功,查看/data00/數據目錄:
            .....
            -rw-rw---- 1 root root   8620 Nov 22 15:01 users00.frm
            -rw-rw---- 1 root root     40 Nov 22 15:01 users00.par
            lrwxrwxrwx 1 root root     24 Nov 22 14:39 users00#P#p1.MYD -> /data00/users00#P#p1.MYD
            lrwxrwxrwx 1 root root     24 Nov 22 14:39 users00#P#p1.MYI -> /data00/users00#P#p1.MYI
            lrwxrwxrwx 1 root root     24 Nov 22 14:39 users00#P#p2.MYD -> /data00/users00#P#p2.MYD
            lrwxrwxrwx 1 root root     24 Nov 22 14:39 users00#P#p2.MYI -> /data00/users00#P#p2.MYI
            lrwxrwxrwx 1 root root     24 Nov 22 14:39 users00#P#p3.MYD -> /data00/users00#P#p3.MYD
            lrwxrwxrwx 1 root root     24 Nov 22 14:39 users00#P#p3.MYI -> /data00/users00#P#p3.MYI
            lrwxrwxrwx 1 root root     24 Nov 22 15:01 users00#P#s0.MYD -> /data00/users00#P#s0.MYD
            lrwxrwxrwx 1 root root     24 Nov 22 15:01 users00#P#s0.MYI -> /data00/users00#P#s0.MYI
            lrwxrwxrwx 1 root root     24 Nov 22 15:01 users00#P#s1.MYD -> /data00/users00#P#s1.MYD
            lrwxrwxrwx 1 root root     24 Nov 22 15:01 users00#P#s1.MYI -> /data00/users00#P#s1.MYI
            ......

            以下是合并s0s1分區為p0分區

            mysql> alter table users00 reorganize partition s0,s1 into( partition p0 values less than(10000) data directory="/data00/" index directory="/data00/");
            Query OK, 0 rows affected (0.03 sec)
            Records: 0  Duplicates: 0  Warnings: 0

            此時s0,s1又合并成了p0分區
            ....
            -rw-rw---- 1 root root   8620 Nov 22 15:04 users00.frm
            -rw-rw---- 1 root root     32 Nov 22 15:04 users00.par
            lrwxrwxrwx 1 root root     24 Nov 22 15:04 users00#P#p0.MYD -> /data00/users00#P#p0.MYD
            lrwxrwxrwx 1 root root     24 Nov 22 15:04 users00#P#p0.MYI -> /data00/users00#P#p0.MYI
            lrwxrwxrwx 1 root root     24 Nov 22 14:39 users00#P#p1.MYD -> /data00/users00#P#p1.MYD
            lrwxrwxrwx 1 root root     24 Nov 22 14:39 users00#P#p1.MYI -> /data00/users00#P#p1.MYI
            lrwxrwxrwx 1 root root     24 Nov 22 14:39 users00#P#p2.MYD -> /data00/users00#P#p2.MYD
            lrwxrwxrwx 1 root root     24 Nov 22 14:39 users00#P#p2.MYI -> /data00/users00#P#p2.MYI
            lrwxrwxrwx 1 root root     24 Nov 22 14:39 users00#P#p3.MYD -> /data00/users00#P#p3.MYD
            lrwxrwxrwx 1 root root     24 Nov 22 14:39 users00#P#p3.MYI -> /data00/users00#P#p3.MYI
            ....

            詳細的分區信息及功能介紹請參考mysql參考手冊,里面有非常詳細的介紹,我這里只是簡單的實現,很多地方都不夠詳細,只作為數據庫分表及數據分離的參考

            posted on 2009-06-09 13:43 肥仔 閱讀(1634) 評論(0)  編輯 收藏 引用 所屬分類: 數據庫

            久久亚洲国产精品五月天婷| 久久精品亚洲中文字幕无码麻豆 | 国产亚洲精久久久久久无码77777| 久久久91人妻无码精品蜜桃HD| 久久无码一区二区三区少妇| 麻豆久久久9性大片| 久久综合综合久久综合| 国产精品一区二区久久精品无码 | 蜜臀av性久久久久蜜臀aⅴ| 国内精品久久久久影院免费| 国产视频久久| 人妻无码αv中文字幕久久琪琪布 人妻无码久久一区二区三区免费 人妻无码中文久久久久专区 | 久久免费观看视频| 久久亚洲中文字幕精品有坂深雪| 国产成人精品久久亚洲高清不卡| 久久经典免费视频| 91精品国产91久久久久久蜜臀| 久久久久久A亚洲欧洲AV冫| 一级A毛片免费观看久久精品| 国产69精品久久久久9999APGF | 亚洲精品tv久久久久| 亚洲国产成人久久综合一区77| 久久精品国产亚洲AV香蕉| 久久偷看各类wc女厕嘘嘘| 国内精品伊人久久久久影院对白 | 国产成人无码精品久久久免费| 久久午夜福利电影| 久久99热这里只有精品国产| 一本久久a久久精品亚洲| 国产精品午夜久久| 日本欧美久久久久免费播放网| 久久精品无码一区二区三区免费| 久久久午夜精品| 国产精品九九久久精品女同亚洲欧美日韩综合区 | 青青草原综合久久大伊人导航| 国产激情久久久久影院| 亚洲国产精品成人AV无码久久综合影院| 伊人久久无码中文字幕| 91精品国产综合久久香蕉| 97超级碰碰碰久久久久| 久久久久99这里有精品10|