数据库切库、分库、分表


 

切库的基础和实际运用—读写分离:

如何方便进行读写分离,目前有两种方式:

1.动态数据源切换

它是指程序运行时,把数据源动态的织入到程序中,让指定的程序连接主库还是从库


2.直接定义查数据源和写数据源

直接在项目里定义两个数据库连接,一个是主库连接一个是从库连接,更新数据的时候我们读取主库连接,查询数据的时候读取从库连接

 

多数据源(切库)和分库的区别:

它们都是底层是多个数据库在提供服务。

分库是属于在微服务应用拆分的时候都有自己的数据库,而多数据源是在没有进行应用拆分的时候就已经分成两个库了,根据业务使用不同的代码连接不同的数据库。

Java初高级一起学习分享,共同学习才是最明智的选择,喜欢的话可以我的学习群64弍46衣3凌9,或加资料群69似64陆0吧3

数据库的分表:

什么时候考虑分表?

当一个数据表很大,大到我们做了sql和索引优化之后,基本操作的速度还是影响使用,我们就必须考虑分表了 

  Java初高级一起学习分享,共同学习才是最明智的选择,喜欢的话可以我的学习群64弍46衣3凌9,或加资料群69似64陆0吧3
分表的好处:
分表后单表的并发能力提高了,写操作效率也会提高。其次是查询一次的时间短了,数据分布在不同的文件里,磁盘的io磁盘io性能也提高了,
磁盘的读写锁影响的数据量变小,插入数据库需要重新建立的索引变少。
 
分表策略:
横向分表
将表中不同的数据行按照一定规律分布到不同的数据库表中(这些表保存在同一个数据库中),这样来降低单表数据量,优化查询性能。
 
纵向分表
一般根据数据的活跃度进行划分。
 
mybatis分表插件shardbatis2.0

在Spring Boot中使用Redisson切换Redis数据库是相对简单的。首先,您需要在您的项目中添加Redisson的依赖。在pom.xml文件中添加以下依赖项: ```xml <dependency> <groupId>org.redisson</groupId> <artifactId>redisson-spring-boot-starter</artifactId> <version>3.16.1</version> </dependency> ``` 接下来,您需要在application.properties或application.yml文件中配置Redis连接信息: ```properties spring.redis.host=127.0.0.1 spring.redis.port=6379 spring.redis.password= ``` 然后,在您的代码中,您可以使用`RedissonClient`接口来连接Redis,并使用`getBucket`方法来获取Redisson对象,从而实现切换Redis数据库。例如: ```java import org.redisson.api.RedissonClient; import org.redisson.api.RBucket; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; @Service public class RedisService { @Autowired private RedissonClient redissonClient; public void switchDatabase(int databaseIndex) { redissonClient.getBucket("databaseIndex").set(databaseIndex); } public int getCurrentDatabase() { RBucket<Integer> bucket = redissonClient.getBucket("databaseIndex"); return bucket.get(); } // 其他操作方法... } ``` 在上面的示例代码中,`switchDatabase`方法用于切换Redis数据库,将数据库索引存储在名为`databaseIndex`的Redis键中。`getCurrentDatabase`方法用于获取当前正在使用的数据库索引。 这样,您就可以使用Redisson在Spring Boot中切换Redis数据库了。注意,Redis数据库索引从0开始,您可以根据自己的需求进行调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值