服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - Mysql - MySQL数据库表的合并与分区实现介绍

MySQL数据库表的合并与分区实现介绍

2022-11-20 17:29PHP经验分享 Mysql

今天我们来聊聊处理大数据时Mysql的存储优化。当数据达到一定量时,一般的存储方式就无法解决高并发问题了。最直接的MySQL优化就是分区分表,以下是我个人对分区分表的笔记

创建数据表

创建数据表的,使用字符串应该遵循的原则

  • 从速度方面考虑,要选择固定的列,可以使用CHAR类型
  • 要节省空间,使用动态的列,可以使用VARCHAR类型
  • 要将列中的内容限制为一种选择,可以使用ENUM类型
  • 允许在一列中有多个条目,可以使用SET类型
  • 如果要搜索的内容不区分大小写,可以使用TEXT类型
  • 如果要搜索的内容区分大小写,可以使用BLOB类型

创建数据表其实就是在已经创建好的数据库中建立新表。

数据表属于数据库,在创建数据表之前,应该使用语句

"use <数据库名>" ;      //表明使用哪个数据库。

如果你没有选择数据库的话,MySQL会抛出No database selected 的错误提示

创建数据表的语句为:

create table 数据表名称(

字段名1 数据类型 [完整约束条件] [默认值],

字段名2 数据类型 [完整约束条件] [默认值],

字段名3 数据类型 [完整约束条件] [默认值],

"数据表名称"是创建数据表的名字。"字段名"是数据表的列名,"完整性约束条件"是字段的特殊约束条件

使用create table 创建表时,必须指定以下信息:

数据表名不区分大小写,且不能使用SQL中的关键字,如DROP,INSERT等。

如果数据表中有多个字段(列),字段(列)的名称和数据类型要用英文逗号隔开。

数据库表合并

合并表:把多个结果相同的的表合并为一个容器。

容器的类型:Myisam,存储引擎:merge

存在的问题:有重复的行

?
1
2
3
create table packtable(
  id ....
)engine=merge unique=(table1,table2);

数据库表分区

表的分区:

  • 水平分区:根据某个字段进行分区(RANGE分区)
?
1
2
3
4
5
6
7
8
9
10
11
create table test1(
id int(10) primary key auto_increment,
 score int(3)
)engine=innodb default charset=utf8 partition by range(score)(
//根据score字段分区,score小于60的在p1分区
  partition p1 values less than(60),
//根据score字段分区,score小于70的在p2 分区
 partition p2 values less than(70),
 //根据score字段分区,score大于70的在p3 分区
  partition p3 values lessthan maxvalue
 );
  • list分区:第一选择基于某 列的值是否属于某个 集合
?
1
2
3
4
5
6
7
8
9
create table test1(
     id int(10) primary key auto_increment,
     branch_id int(3)
)engine=innodb default charset=utf8 partition by list(branch_id  )(
    //根据branch_id 字段分区,branch_id  在1,2,3之中的为p1分区
     partition p1 values less in(1,2,3),
    //根据branch_id 字段分区,branch_id  在7,8,9 之中的为p2分区
     partition p2 values less in(7,8,9)
);
  • hash分区:支持数值类型
?
1
2
3
4
5
6
7
--
-- 根据birthda字段获取月份,再根据月份进行分区储存,一共分12个区;
--
create table test1(
 id int(10) primary key auto_increment,
 birthday date
)engine=innodb default charset=utf8 partition by hash(month(birthday))  partitions 12;
  • 线性分区(linear hash):大数据是增加,合并,拆分速度更快
?
1
2
3
4
5
6
7
--
-- 根据branch_id字段进行分区储存,一共分5个区;
--
create table test1(
 id int(10) primary key auto_increment,
 branch_id int(3)
)engine=innodb default charset=utf8 partition by linear hash (branch_id  ) partitions 5;
  • key分区:可以计算一列或者多列进行分区
?
1
2
3
4
5
6
7
--
-- 根据branch_id字段进行分区储存,一共分5个区;
--
create table test1(
 id int(10) primary key auto_increment,
 branch_id int(3)
)engine=innodb default charset=utf8 partition by key (branch_id  ) partitions 5;

到此这篇关于MySQL数据库表的合并与分区实现介绍的文章就介绍到这了,更多相关MySQL数据库表内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/weixin_39151744/article/details/126499155

延伸 · 阅读

精彩推荐
  • MysqlMySQL 权限控制细节分析

    MySQL 权限控制细节分析

    这篇文章主要介绍了MySQL 权限控制细节分析的相关资料,帮助大家更好的理解和学习使用MySQL,感兴趣的朋友可以了解下...

    AsiaYe11612021-04-30
  • MysqlMySQL InnoDB和MyISAM数据引擎的差别分析

    MySQL InnoDB和MyISAM数据引擎的差别分析

    InnoDB和MyISAM是在使用MySQL最常用的两个表类型,各有优缺点,视具体应用而定。基本的差别为:MyISAM类型不支持事务处理等高级处理,而InnoDB类型支持 ...

    mysql教程网1852019-11-18
  • MysqlNavicat连接MySQL时报10060、1045错误及my.ini位置问题

    Navicat连接MySQL时报10060、1045错误及my.ini位置问题

    这篇文章主要介绍了Navicat连接MySQL的10060及1045报错,my.ini位置,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价...

    我想我会更好13412021-01-10
  • Mysqlinnodb引擎redo文件维护方法

    innodb引擎redo文件维护方法

    下面小编就为大家带来一篇innodb引擎redo文件维护方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    MYSQL教程网4542020-07-21
  • Mysqlmysql下载与安装过程详解

    mysql下载与安装过程详解

    这篇文章主要介绍了mysql下载与安装过程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小...

    weixin_403965106062020-09-18
  • Mysqlmysql decimal数据类型转换的实现

    mysql decimal数据类型转换的实现

    这篇文章主要介绍了mysql decimal数据类型转换的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下...

    诸葛老刘7232021-04-12
  • MysqlMySQL基于DOS命令行登录操作实例(图文说明)

    MySQL基于DOS命令行登录操作实例(图文说明)

    这篇文章主要介绍了MySQL基于DOS命令行登录操作,以图文形式结合实例说明了MySQL登录命令的基本用法,非常简单易懂需要的朋友可以参考下 ...

    服务器之家5062020-05-29
  • MysqlMysql 5.7.20压缩版下载和安装简易教程

    Mysql 5.7.20压缩版下载和安装简易教程

    这篇文章主要介绍了Mysql 5.7.20压缩版下载和安装简易教程,非常不错,具有参考借鉴价值,需要的朋友可以参考下 ...

    csdn_ttk4822020-08-18