预览加载中,请您耐心等待几秒...
在线预览结束,喜欢就下载吧,查找使用更方便
如果您无法下载资料,请参考说明:
1、部分资料下载需要金币,请确保您的账户上有足够的金币
2、已购买过的文档,再次下载不重复扣费
3、资料包下载后请先用软件解压,在使用对应软件打开
mysql分表方法实现
一般来说,当我们的数据库的数据超过了100w记录的时候就应该考虑分表或者分区了,这次我来详细说说分表的一些方法。目前我所知道的方法都是MYISAM的,INNODB如何做分表并且保留事务和外键,我还不是很了解。
一般来说,当我们的数据库的数据超过了100w记录的时候就应该考虑分表或者分区了,这次我来详细说说分表的一些方法。目前我所知道的方法都是MYISAM的,INNODB如何做分表并且保留事务和外键,我还不是很了解。
首先,我们需要想好到底分多少个表,前提当然是满足应用。这里我使用了一个比较简单的分表方法,就是根据自增id的尾数来分,也就是说分0-9一共10个表,其取值也很好做,就是对10进行取模。另外,还可以根据某一字段的md5值取其中几位进行分表,这样的话,可以分的表就很多了。
好了,先来创建表吧,代码如下
Sql代码
Sql代码
CREATETABLE`test`.`article_0`(
`id`BIGINT(20)NOTNULL,
`subject`VARCHAR(200)NOTNULL,
`content`TEXTNOTNULL,
PRIMARYKEY(`id`)
)ENGINE=MYISAMCHARACTERSETutf8COLLATEutf8_general_ci
CREATETABLE`test`.`article_1`(
`id`BIGINT(20)NOTNULL,
`subject`VARCHAR(200)NOTNULL,
`content`TEXTNOTNULL,
PRIMARYKEY(`id`)
)ENGINE=MYISAMCHARACTERSETutf8COLLATEutf8_general_ci
CREATETABLE`test`.`article_2`(
`id`BIGINT(20)NOTNULL,
`subject`VARCHAR(200)NOTNULL,
`content`TEXTNOTNULL,
PRIMARYKEY(`id`)
)ENGINE=MYISAMCHARACTERSETutf8COLLATEutf8_general_ci
CREATETABLE`test`.`article_3`(
`id`BIGINT(20)NOTNULL,
`subject`VARCHAR(200)NOTNULL,
`content`TEXTNOTNULL,
PRIMARYKEY(`id`)
)ENGINE=MYISAMCHARACTERSETutf8COLLATEutf8_general_ci
CREATETABLE`test`.`article_4`(
`id`BIGINT(20)NOTNULL,
`subject`VARCHAR(200)NOTNULL,
`content`TEXTNOTNULL,
PRIMARYKEY(`id`)
)ENGINE=MYISAMCHARACTERSETutf8COLLATEutf8_general_ci
CREATETABLE`test`.`article_5`(
`id`BIGINT(20)NOTNULL,
`subject`VARCHAR(200)NOTNULL,
`content`TEXTNOTNULL,
PRIMARYKEY(`id`)
)ENGINE=MYISAMCHARACTERSETutf8COLLATEutf8_general_ci
CREATETABLE`test`.`article_6`(
`id`BIGINT(20)NOTNULL,
`subject`VARCHAR(200)NOTNULL,
`content`TEXTNOTNULL,
PRIMARYKEY(`id`)
)ENGINE=MYISAMCHARACTERSETutf8COLLATEutf8_general_ci
CREATETABLE`test`.`article_7`(
`id`BIGINT(20)NOTNULL,
`subject`VARCHAR(200)NOTNULL,
`content`TEXTNOTNULL,
PRIMARYKEY(`id`)
)ENGINE=MYISAMCHARACTERSETutf8COLLATEutf8_general_ci
CREATETABLE`test`.`article_8`(
`id`BIGINT(20)NOTNULL,
`subject`VARCHAR(200)NOTNULL,
`content`TEXTNOTNULL,
PRIMARYKEY(`id`)
)ENGINE=MYISAMCHARACTERSETutf8COLLATEutf8_general_ci
CREATETABLE`test`.`arti