美文网首页
Mysql数据库分区

Mysql数据库分区

作者: 极简纯粹_ | 来源:发表于2017-12-01 15:36 被阅读0次

一、数据库分区的基本概念
数据库分区是一种物理数据库设计技术,主要目的是为了在特定的SQL操作中减少数据读写的总量以缩减响应时间[来自https://baike.baidu.com/item/%E6%95%B0%E6%8D%AE%E5%BA%93%E5%88%86%E5%8C%BA/3801074?fr=aladdin]
二、为什么要进行分区
在日常开发中对于百万级乃至千万级记录的数据库插询和插入往往会耗时过长,这样会导致B/S或者C/S架构中的应用程序卡慢的现象,十分影响用户体验。数据库分区可以减少数据库的负担,提高表的增删改查效率。
三、数据库分区技术
1)range分区-->基于属于一个给定连续区间的列值, 把多行分配给分区。
假定你创建了一个如下的表, 该表保存有20家音像店的职员记录, 这20家音像店的编号从1到20。 如果你想将其分成4个小分区, 那么你可以采用RANGE分区, 创建的数据库表如下:
mysql-> CREATE TABLE employees (
-> id INT NOT NULL,
-> fname VARCHAR(30),
-> lname VARCHAR(30),
-> hired DATE NOT NULL DEFAULT '1970-01-01',
-> separated DATE NOT NULL DEFAULT '9999-12-31',
-> job_code INT NOT NULL,
-> store_id INT NOT NULL
-> ) ENGINE=Myisam DEFAULT CHARSET=utf8
-> PARTITION BY RANGE (store_id) (
-> PARTITION P0 VALUES LESS THAN (6),
-> PARTITION P1 VALUES LESS THAN (11),
-> PARTITION P2 VALUES LESS THAN (16),
-> PARTITION P3 VALUES LESS THAN (21)
-> );
如果你想把不同时期离职的员工进行分别存储, 那么你可以将日期字段 separated (即离职时间) 作为一个 key, 创建的 SQL 语句如下:
mysql-> CREATE TABLE employees (
-> id INT NOT NULL,
-> fname VARCHAR(30),
-> lname VARCHAR(30),
-> hired DATE NOT NULL DEFAULT '1970-01-01',
-> separated DATE NOT NULL DEFAULT '9999-12-31',
-> job_code INT NOT NULL,
-> store_id INT NOT NULL
-> ) ENGINE=Myisam DEFAULT CHARSET=utf8
-> PARTITION BY RANGE (YEAR(separated)) (
-> PARTITION P0 VALUES LESS THAN (2001),
-> PARTITION P1 VALUES LESS THAN (2011),
-> PARTITION P2 VALUES LESS THAN (2021),
-> PARTITION P3 VALUES LESS THAN MAXVALUE
-> );
2)List分区-->类似于按 RANGE 分区, 区别在于 LIST 分区是基于列值匹配一个离散值集合中的某个值来进行选择。
3) HASH分区: 基于用户定义的表达式的返回值来进行选择分区, 该表达式使用将要插入到表中的这些行的列值进行计算, 这个函数可以包含 Mysql 中有效的、产生非负整数值的任何表达式
4)KEY分区: 累世于按 HASH 分区, 区别在于 KEY 分区只支持计算一列或多列, 且 Mysql 服务器提供其自身的哈希函数
参考:http://blog.csdn.net/l1028386804/article/details/50729565

相关文章

  • mysql分库分表

    课程内容 mysql分区 水平切分 垂直切分 1. mysql分区 1.1 什么是分区? mysql数据库中的数据...

  • [转]MYSQL--表分区、查看,建立,删除

    一、 mysql分区简介 数据库分区 数据库分区是一种物理数据库设计技术。虽然分区技术可以实现很多效果...

  • 对MySQL交换分区的实践

    前言 在介绍交换分区之前,我们先了解一下 mysql 分区。 数据库的分区有两种:水平分区和垂直分区。而MySQL...

  • MySQL的分区、分表、集群、优化

    MySQL的分区 MySQL分区表是在数据库层面,MySQL自己实现的分表功能,在很大程度上简化了分表的难度。物理...

  • Mysql数据库分区(PARTITION)操作记录

    mysql的数据库分区是什么? mysql的数据库分区,是将数据表的数据文件和索引文件按照规则分别存储在不同文件中...

  • MySQL分区

    什么是数据库分区:以mysql为例,mysql数据库中的数据是以文件的形势存在磁盘上的,默认放在/mysql/da...

  • mysql分区详解

    一,什么是数据库分区前段时间写过一篇关于mysql分表的的文章,下面来说一下什么是数据库分区,以mysql为例。m...

  • 数据库的分区:水平分区,垂直分区

    它是一种物理数据库设计技术,MySQL数据库默认使用水平分区。2.1 水平分区:对表的行进行分区,不同分组中物理分...

  • 深入理解MySQL分区(Partition)

    什么是数据库分区? Mysql数据库中的数据是以文件的形式保存在磁盘上的,默认放在mysql/data路径,不同的...

  • 数据库分区Partitioning, 2022-07-16

    (2022.07.16 Sat) 数据库特别是MySQL的分区(partitioning)是一种数据库设计技术,用...

网友评论

      本文标题:Mysql数据库分区

      本文链接:https://www.haomeiwen.com/subject/nirwbxtx.html