当前位置: 首页 > news >正文

个人业务网站建设企业展厅设计公司企业展厅设计公司

个人业务网站建设,企业展厅设计公司企业展厅设计公司,郑州设计网页的公司,做网站架构图配置多数据源 模拟多库场景 适用于多种场景: 多库(操作的表分布在不同数据库当中),读写分离(有的数据库负责查询的功能,有的数据库负责增删该的功能),一主多从,混合模式等 第一步: 模拟多库,在mybatis_plus数据库中创建user表,在mybatis_plus_1数据库中创建product表 --创建…

配置多数据源

模拟多库场景

适用于多种场景: 多库(操作的表分布在不同数据库当中),读写分离(有的数据库负责查询的功能,有的数据库负责增删该的功能),一主多从,混合模式等

第一步: 模拟多库,在mybatis_plus数据库中创建user表,在mybatis_plus_1数据库中创建product表

--创建mybatis_plus数据库
CREATE DATABASE `mybatis_plus` /*!40100 DEFAULT CHARACTER SET utf8mb4 */;
use `mybatis_plus`;
--创建user表
CREATE TABLE `t_user` (`id` bigint(20) NOT NULL COMMENT '主键ID',`name` varchar(30) DEFAULT NULL COMMENT '姓名',`age` int(11) DEFAULT NULL COMMENT '年龄',`email` varchar(50) DEFAULT NULL COMMENT '邮箱',PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
--向user表中插入数据
INSERT INTO t_user (id, name, age, email) VALUES
(1, 'Jone', 18, 'test1@baomidou.com'),
(2, 'Jack', 20, 'test2@baomidou.com'),
(3, 'Tom', 28, 'test3@baomidou.com'),
(4, 'Sandy', 21, 'test4@baomidou.com'),
(5, 'Billie', 24, 'test5@baomidou.com');
--创建mybatis_plus_1数据库
CREATE DATABASE `mybatis_plus_1` /*!40100 DEFAULT CHARACTER SET utf8mb4 */;
use `mybatis_plus_1`;
--创建product表
CREATE TABLE t_product(
id BIGINT(20) NOT NULL COMMENT '主键ID',
name VARCHAR(30) NULL DEFAULT NULL COMMENT '商品名称',
price INT(11) DEFAULT 0 COMMENT '价格',
version INT(11) DEFAULT 0 COMMENT '乐观锁版本号',
PRIMARY KEY (id)
);
--向product表插入数据
INSERT INTO t_product (id, NAME, price) VALUES (1, '外星人笔记本', 100);

第二步:在pom.xml文件中引入多数据源使用的依赖

<!--配置多数据源需要使用的依赖-->
<dependency><groupId>com.baomidou</groupId><artifactId>dynamic-datasource-spring-boot-starter</artifactId><version>3.5.0</version>
</dependency>

第三步: 在appilcation.yaml文件中添加配置多数据源的配置选项

spring:# 配置数据源信息datasource:dynamic:# 设置默认的数据源或者数据源组,默认值即为masterprimary: master# 严格匹配数据源(默认false),true表示如果未匹配到指定数据源时抛异常,false表示如果未匹配到指定的数据源就使用默认的数据源strict: falsedatasource:master: # 默认数据源url: jdbc:mysql://localhost:3306/mybatis_plus?characterEncoding=utf-8&useSSL=falsedriver-class-name: com.mysql.cj.jdbc.Driverusername: rootpassword: 123456slave_1: # 其他数据源url: jdbc:mysql://localhost:3306/mybatis_plus_1?characterEncoding=utf-8&useSSL=falsedriver-class-name: com.mysql.cj.jdbc.Driverusername: rootpassword: 123456

第四步: 创建实体类封装表中查询的数据

//封装用户信息的实体类
@Data
@TableName("t_user")
public class User {private Integer id;private String name;private Integer age;private String email;
}
//封装产品信息的实体类
@Data
@TableName("t_product")
public class Product {private Integer id;private String name;private Integer price;private Integer version;
}

第五步: 编写User和Product对应的mapper接口和service接口

@Repository
public interface ProductMapper extends BaseMapper<Product> {
}@Repository
public interface UserMapper extends BaseMapper<User> {
}public interface UserService extends IService<User> {}public interface ProductService extends IService<Product> {}

第六步: 创建User和Product实体类对应的service接口的实现类,使用@DS注解指定当前类或方法要操作的数据源

  • @Ds注解使用在方法上或类上(使用在类上表示类中所有的方法默认都有该注解)
  • @Ds注解在类和方法上同时存在则遵循就近原则,方法上指定操作的数据源优先于类上指定操作的数据源
注解结果
没有@DS注解操作默认的数据源
@DS(“dsName”)dsName为要操作的数据源名称
@Service
@DS("master") //t_user表在master数据源当中
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implementsUserService {
}@Service
@DS("slave_1")//t_product表在slave_1数据源当中
public class ProductServiceImpl extends ServiceImpl<ProductMapper, Product> implements ProductService {
}

第七步: 编写Spring Boot主程序的启动类

@SpringBootApplication
@MapperScan("com.atguigu.mybatisplus.mapper")// 扫描mapper接口所在的包
public class MybatisPlusDatasourceApplication {public static void main(String[] args) {SpringApplication.run(MybatisPlusDatasourceApplication.class, args);}
}

第八步: 由于t_user表和t_product在两个不同的数据库(数据源)中,如果通过一个测试方法可以分别获取到用户数据与商品数据成功说明多库模拟成功

@SpringBootTest
public class MybatisPlusDatasourceApplicationTests {@Autowiredprivate UserService userService;@Autowiredprivate ProductService productService;@Testpublic void testDynamicDataSource(){// 输出查询出来的对象System.out.println(userService.getById(1));System.out.println(productService.getById(1));}
}

模拟读写分离

实现读写分离的效果

  • 写操作: 增删改操作的方法加上@DS注解指定操作主库数据源,因为只有主数据源才可以把更新的操作同步到从数据源
  • 读操作: 查询操作的方法指定操作从库数据源
http://www.yayakq.cn/news/302632/

相关文章:

  • 文件备案网站建设方案域名网站怎么做的
  • 网站改版 优势做网站可以申请个体户么
  • 做网站被骗首付款怎么报案做网站主机要选好
  • 有没有帮别人做图片的网站赚钱深圳建设交易公司
  • 电商网站开发商广州设计公司排名前十强
  • 做网站多大python语言基础知识
  • 深圳公司网站开发wordpress 2012主题
  • wordpress自建电商网站刘家窑做网站
  • 网站和域名区别个人网站意义
  • 用织梦的网站怎么做推广余江网站建设
  • 北网站建设淘宝视频怎么下载
  • 做视频网站需要哪些手续华为软件开发工程师
  • asp 企业网站管理系统如何经营一个购物网站
  • 网页.网站.主页.网址.域名有什么联系网站建设与管理 ppt
  • 做磁力链网站做网站需要买多大空间
  • 学生模拟网站开发百度网站免费优化软件下载
  • 网站建站公司一站式服务企业管理系统项目经历怎么写简历范文
  • 个人资讯网站建设深圳哪家网站建设公司好
  • 好的做详情页的网站有哪些北京做网站个人
  • 网站优化外包济南微信网站
  • 广东网络公司网站购物网站的搜索框用代码怎么做
  • 徐典超 网站建设网站栏目收录
  • 网站仿静态乐陵seo优化推广
  • 购物网站开发教程东莞机电学校网站建设与管理
  • 怎么接做网站的任务手机之家官方网
  • 成都微信网站建设多app小程序开发价格
  • 网站设计报价表中山低价网站建设
  • 汽车网站开发毕业设计论文用织梦做网站能练技术吗
  • 北京做网站网络公司京东的网站建设规划
  • 语言 网站开发网站如何修改后台密码