怎么在MySQL数据库中实现分表分库操作
这篇文章将为大家详细讲解有关怎么在MySQL数据库中实现分表分库操作,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。
分表分库
垂直拆分就是要把表按模块划分到不同数据库表中(当然原则还是不破坏第三范式),这种拆分在大型网站的演变过程中是很常见的。当一个网站还在很小的时候,只有小量的人来开发和维护,各模块和表都在一起,当网站不断丰富和壮大的时候,也会变成多个子系统来支撑,这时就有按模块和功能把表划分出来的需求。其实,相对于垂直切分更进一步的是服务化改造,说得简单就是要把原来强耦合的系统拆分成多个弱耦合的服务,通过服务间的调用来满足业务需求看,因此表拆出来后要通过服务的形式暴露出去,而不是直接调用不同模块的表,淘宝在架构不断演变过程,最重要的一环就是服务化改造,把用户、交易、店铺、宝贝这些核心的概念抽取成独立的服务,也非常有利于进行局部的优化和治理,保障核心模块的稳定性
垂直拆分用于分布式场景。
上面谈到垂直切分只是把表按模块划分到不同数据库,但没有解决单表大数据量的问题,而水平切分就是要把一个表按照某种规则把数据划分到不同表或数据库里。例如像计费系统,通过按时间来划分表就比较合适,因为系统都是处理某一时间段的数据。而像SaaS应用,通过按用户维度来划分数据比较合适,因为用户与用户之间的隔离的,一般不存在处理多个用户数据的情况,简单的按user_id范围来水平切分
通俗理解:水平拆分行,行数据拆分到不同表中, 垂直拆分列,表数据拆分到不同表中
思路:在大型电商系统中,每天的会员人数不断的增加。达到一定瓶颈后如何优化查询。
可能大家会想到索引,万一用户量达到上亿级别,如何进行优化呢?
使用水平分割拆分数据库表。
使用水平分割拆分表,具体根据业务需求,有的按照注册时间、取摸、账号规则、年份等。
使用取摸方式分表首先我创建三张表 user0 / user1 /user2 , 然后我再创建 uuid表,该表的作用就是提供自增的id。
createtableuser0(idintunsignedprimarykey,namevarchar(32)notnulldefault'',pwdvarchar(32)notnulldefault'')engine=myisamcharsetutf8;createtableuser1(idintunsignedprimarykey,namevarchar(32)notnulldefault'',pwdvarchar(32)notnulldefault'')engine=myisamcharsetutf8;createtableuser2(idintunsignedprimarykey,namevarchar(32)notnulldefault'',pwdvarchar(32)notnulldefault'')engine=myisamcharsetutf8;createtableuuid(idintunsignedprimarykeyauto_increment)engine=myisamcharsetutf8;创建一个demo项目
POM文件
<parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>1.3.3.RELEASE</version></parent><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-jdbc</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency></dependencies>
Service代码
@ServicepublicclassUserService{@AutowiredprivateJdbcTemplatejdbcTemplate;publicStringregit(Stringname,Stringpwd){//1.先获取到自定增长IDStringidInsertSQL="INSERTINTOuuidVALUES(NULL);";jdbcTemplate.update(idInsertSQL);LonginsertId=jdbcTemplate.queryForObject("selectlast_insert_id()",Long.class);//2.判断存储表名称StringtableName="user"+insertId%3;//3.注册数据StringinsertUserSql="INSERTINTO"+tableName+"VALUES('"+insertId+"','"+name+"','"+pwd+"');";System.out.println("insertUserSql:"+insertUserSql);jdbcTemplate.update(insertUserSql);return"success";}publicStringget(Longid){StringtableName="user"+id%3;Stringsql="selectnamefrom"+tableName+"whereid="+id;System.out.println("SQL:"+sql);Stringname=jdbcTemplate.queryForObject(sql,String.class);returnname;}}
Controller
@RestControllerpublicclassUserController{@AutowiredprivateUserServiceuserService;@RequestMapping("/regit")publicStringregit(Stringname,Stringpwd){returnuserService.regit(name,pwd);}@RequestMapping("/get")publicStringget(Longid){Stringname=userService.get(id);returnname;}}
关于怎么在MySQL数据库中实现分表分库操作就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。