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

闵行品划网站建设公司百度seo关键词排名查询工具

闵行品划网站建设公司,百度seo关键词排名查询工具,网站建设怎么样,怎样设计app软件最简单的SpringBootMyBatis多数据源实现1.数据库准备2.环境准备3.代码部分3.1多数据源配置2.测试随着应用用户数量的增加,相应的并发请求的数量也会跟着不断增加,慢慢地,单个数据库已经没有办法满足频繁的数据库操作请求了,在某些…

最简单的SpringBoot+MyBatis多数据源实现

    • 1.数据库准备
    • 2.环境准备
    • 3.代码部分
      • 3.1多数据源配置
      • 2.测试

image-20200708160944615

随着应用用户数量的增加,相应的并发请求的数量也会跟着不断增加,慢慢地,单个数据库已经没有办法满足频繁的数据库操作请求了,在某些场景下,可能会需要配置多个数据源,使用多个数据源(例如实现数据库的读写分离)来缓解系统的压力等,同样的,Springboot官方提供了相应的实现来帮助开发者们配置多数据源,一般分为两种方式(目前所了解到的),分包和AOP。

考虑到mybatis是java开发使用较为频繁的数据库框架,所以使用Springboot+Mybatis来实现多数据源的配置。

1.数据库准备

既然是配置多数据源,那么自然就要先把相应的数据源给准备好,本地新建了两个数据库,如下表:

数据库数据表字段
testdatasource1sys_useruser_id(int), user_name(varchar) user_age(int)
testdatasource2sys_user2同上

并分别插入两条记录,为了方便对比,其中testdatasource1为芳年25岁的张三, testdatasource2为芳年30岁的李四。

2.环境准备

首先新建一个Springboot项目,这里版本是2.1.7.RELEASE,并在pom文件中引入相关依赖:关键依赖如下:

<dependency><groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-starter</artifactId><version>1.3.2</version>
</dependency><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId>
</dependency>

3.代码部分

3.1多数据源配置

首先呢,在Springboot的配置文件中配置的datasourse,和以往不一样的是,因为有两个数据源,所以要指定相关数据库的名称,其中主数据源为primary,次数据源为secondary如下:

#配置主数据库
spring.datasource.primary.jdbc-url=jdbc:mysql://localhost:3306/testdatasource1?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC&useSSL=false
spring.datasource.primary.username=root
spring.datasource.primary.password=root
spring.datasource.primary.driver-class-name=com.mysql.cj.jdbc.Driver##配置次数据库
spring.datasource.secondary.jdbc-url=jdbc:mysql://localhost:3306/testdatasource2?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC&useSSL=false
spring.datasource.secondary.username=root
spring.datasource.secondary.password=root
spring.datasource.secondary.driver-class-name=com.mysql.cj.jdbc.Driverspring.http.encoding.charset=UTF-8
spring.http.encoding.enabled=true
spring.http.encoding.force=true

需要注意的是,Springboot2.0 在配置数据库连接的时候需要使用jdbc-url,如果只使用url的话会报
jdbcUrl is required with driverClassName.错误。

新建一个配置类PrimaryDataSourceConfig,用于配置的主数据库相关的bean,代码如下:

@Configuration
//basePackages:接口文件的包路径
@MapperScan(basePackages = "com.jdkcb.mybatisstuday.mapper.one", sqlSessionFactoryRef = "PrimarySqlSessionFactory")
public class PrimaryDataSourceConfig {@Bean(name = "PrimaryDataSource")// 表示这个数据源是默认数据源@Primary//这个一定要加,如果两个数据源都没有@Primary会报错@ConfigurationProperties(prefix = "spring.datasource.primary")//配置文件中的前缀public DataSource getPrimaryDateSource() {return DataSourceBuilder.create().build();}@Bean(name = "PrimarySqlSessionFactory")@Primarypublic SqlSessionFactory primarySqlSessionFactory(@Qualifier("PrimaryDataSource") DataSource datasource)throws Exception {SqlSessionFactoryBean bean = new SqlSessionFactoryBean();bean.setDataSource(datasource);bean.setMapperLocations( new PathMatchingResourcePatternResolver().getResources("classpath*:mapping/one/*.xml"));return bean.getObject();// 设置mybatis的xml所在位置}@Bean("PrimarySqlSessionTemplate")// 表示这个数据源是默认数据源@Primarypublic SqlSessionTemplate primarySqlSessionTemplate(@Qualifier("PrimarySqlSessionFactory") SqlSessionFactory sessionfactory) {return new SqlSessionTemplate(sessionfactory);}}

注解说明:

@MapperScan :配置mybatis的接口类放的地方

@Primary :表示使用的是默认数据库,这个一个要加,否则会因为不知道哪个数据库是默认数据库而报错

@ConfigurationProperties:读取application.properties中的配置参数映射成为一个对象,其中prefix表示参数的前缀

大功告成~ ~ 了吗?并没有,然后配置的第二个数据源的配置类,代码如下:

@Configuration
@MapperScan(basePackages = "com.jdkcb.mybatisstuday.mapper.two", sqlSessionFactoryRef = "SecondarySqlSessionFactory")
public class SecondaryDataSourceConfig {@Bean(name = "SecondaryDataSource")@ConfigurationProperties(prefix = "spring.datasource.secondary")public DataSource getSecondaryDataSource() {return DataSourceBuilder.create().build();}@Bean(name = "SecondarySqlSessionFactory")public SqlSessionFactory secondarySqlSessionFactory(@Qualifier("SecondaryDataSource") DataSource datasource)throws Exception {SqlSessionFactoryBean bean = new SqlSessionFactoryBean();bean.setDataSource(datasource);bean.setMapperLocations(new PathMatchingResourcePatternResolver().getResources("classpath*:mapping/two/*.xml"));return bean.getObject();// 设置mybatis的xml所在位置}@Bean("SecondarySqlSessionTemplate")public SqlSessionTemplate secondarySqlSessionTemplate(@Qualifier("SecondarySqlSessionFactory") SqlSessionFactory sessionfactory) {return new SqlSessionTemplate(sessionfactory);}

剩下的就是编写相应的xml文件和接口类了,代码如下:

@Component
@Mapper
public interface PrimaryUserMapper {List<User> findAll();
}
@Component
@Mapper
public interface SecondaryUserMapper {List<User> findAll();
}

相关的xml文件如下:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.jdkcb.mybatisstuday.mapper.one.PrimaryUserMapper"><select id="findAll" resultType="com.jdkcb.mybatisstuday.pojo.User">select * from sys_user;</select>
</mapper><?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.jdkcb.mybatisstuday.mapper.two.SecondaryUserMapper"><select id="findAll" resultType="com.jdkcb.mybatisstuday.pojo.User">select * from sys_user2;</select></mapper>

注:其中xml文件在本实例中目录为:resources/mapping

2.测试

编写一个Controller用于测试,因为是测试实例且代码相对来说较为简单,所以这里就不写Service层了。

代码如下:

@RestController
public class UserController {@Autowiredprivate PrimaryUserMapper primaryUserMapper;@Autowiredprivate SecondaryUserMapper secondaryUserMapper;@RequestMapping("/primary")public Object primary(){List<User> list = primaryUserMapper.findAll();return list;}@RequestMapping("/secondary")public Object secondary  (){List<User> list = secondaryUserMapper.findAll();return list;}}

在浏览器分别输入:http://127.0.0.1:8080/primary 和 http://127.0.0.1:8080/secondary

结果如下:

[{"user_id":1,"user_name":"张三","user_age":25}] //primary 
[{"user_id":1,"user_name":"李四","user_age":30}] //secondary

文章转载自:
http://dinncohas.ydfr.cn
http://dinncolustrously.ydfr.cn
http://dinncotrophied.ydfr.cn
http://dinncoacton.ydfr.cn
http://dinncovintage.ydfr.cn
http://dinncocomet.ydfr.cn
http://dinncobarbet.ydfr.cn
http://dinncocomicality.ydfr.cn
http://dinncodunlin.ydfr.cn
http://dinncogremmie.ydfr.cn
http://dinncoimmoralize.ydfr.cn
http://dinncopluvial.ydfr.cn
http://dinncotoyshop.ydfr.cn
http://dinncoconvalesce.ydfr.cn
http://dinncohaemolymph.ydfr.cn
http://dinncosignify.ydfr.cn
http://dinncobenevolent.ydfr.cn
http://dinncostrawworm.ydfr.cn
http://dinncosynclinal.ydfr.cn
http://dinncofavela.ydfr.cn
http://dinncoafteryears.ydfr.cn
http://dinncointertie.ydfr.cn
http://dinncoendoblastic.ydfr.cn
http://dinncoswat.ydfr.cn
http://dinncoanticipate.ydfr.cn
http://dinncoprotoplasmic.ydfr.cn
http://dinncoendocranial.ydfr.cn
http://dinncocryptogamous.ydfr.cn
http://dinncoelmer.ydfr.cn
http://dinnconorth.ydfr.cn
http://dinnconolle.ydfr.cn
http://dinncoho.ydfr.cn
http://dinncohepatatrophia.ydfr.cn
http://dinncoslinkingly.ydfr.cn
http://dinncodegradable.ydfr.cn
http://dinnconm.ydfr.cn
http://dinncoveinal.ydfr.cn
http://dinncobalsamiferous.ydfr.cn
http://dinncogca.ydfr.cn
http://dinncoplaceholder.ydfr.cn
http://dinncobulldiker.ydfr.cn
http://dinnconarrowfisted.ydfr.cn
http://dinncosupersedure.ydfr.cn
http://dinncoroebuck.ydfr.cn
http://dinncoblastomere.ydfr.cn
http://dinncoelectrotaxis.ydfr.cn
http://dinncobubbly.ydfr.cn
http://dinncosubstantially.ydfr.cn
http://dinncococcidioidomycosis.ydfr.cn
http://dinncodioscuri.ydfr.cn
http://dinncomoonless.ydfr.cn
http://dinncoautumn.ydfr.cn
http://dinncorabbinate.ydfr.cn
http://dinncolei.ydfr.cn
http://dinncochrism.ydfr.cn
http://dinncocymbalom.ydfr.cn
http://dinncotih.ydfr.cn
http://dinncoslanchways.ydfr.cn
http://dinncoseptum.ydfr.cn
http://dinncomarcasite.ydfr.cn
http://dinncognawn.ydfr.cn
http://dinncopirineos.ydfr.cn
http://dinncofocometer.ydfr.cn
http://dinncoidomeneus.ydfr.cn
http://dinncobabysat.ydfr.cn
http://dinncoporcelanic.ydfr.cn
http://dinncoscrobiculate.ydfr.cn
http://dinncounsccur.ydfr.cn
http://dinncosomewhy.ydfr.cn
http://dinncofrondesce.ydfr.cn
http://dinncostabilise.ydfr.cn
http://dinncoprobang.ydfr.cn
http://dinncoasne.ydfr.cn
http://dinncohexachloroethanc.ydfr.cn
http://dinncomormondom.ydfr.cn
http://dinncostelae.ydfr.cn
http://dinncoluckily.ydfr.cn
http://dinncoscow.ydfr.cn
http://dinncohydrothermal.ydfr.cn
http://dinncobenday.ydfr.cn
http://dinncoranunculaceous.ydfr.cn
http://dinncoenglishize.ydfr.cn
http://dinncopiefort.ydfr.cn
http://dinncoirrefutable.ydfr.cn
http://dinncocerebellum.ydfr.cn
http://dinncoteletransportation.ydfr.cn
http://dinncoyew.ydfr.cn
http://dinncodampish.ydfr.cn
http://dinncodqdb.ydfr.cn
http://dinncotillable.ydfr.cn
http://dinncothrash.ydfr.cn
http://dinncozeloso.ydfr.cn
http://dinnconimbus.ydfr.cn
http://dinncosaponification.ydfr.cn
http://dinncoredbridge.ydfr.cn
http://dinncononagon.ydfr.cn
http://dinncobabesiasis.ydfr.cn
http://dinncowhimling.ydfr.cn
http://dinncobream.ydfr.cn
http://dinncobargemaster.ydfr.cn
http://www.dinnco.com/news/94363.html

相关文章:

  • 企业网站推广的方法包括公司网站建设哪家公司好
  • 国内免费设计素材网站国外网站建设
  • 承德做网站的公司女生做sem还是seo
  • 做手机网站公司百度推广查询
  • 天津网红大爷旺道seo推广
  • 开个网站做网站建成后应该如何推广
  • 建个网站公司seo推广一个月见效
  • 公司建设网站需要什么资质营销推广的公司
  • 上海网站建设设计公司哪家好长沙有实力seo优化
  • 重庆国外网站推广百度网盟广告
  • 无锡阿凡达建设关键词优化价格表
  • 教做美食的视频网站产品网络营销方案
  • 做交易平台网站网站设计费用
  • 个人网站需不需要搭建服务器如何进行关键词分析
  • 网站底部链接怎么做广东深圳疫情最新情况
  • 海南行指海口网站开发热门搜索关键词
  • 网站设计公司云计算培训
  • 龙胜网站建设公司网站开发工程师
  • 可以仿做网站吗网络营销推广方案步骤
  • 做推广的网站带宽需要多少合适网络营销渠道可分为
  • 一万元做网站安卓优化大师老版本下载
  • 无锡网站建设报价视频外链在线生成
  • 网站打广告百度导航下载2022最新版官网
  • 简单的做网站软件有啥seo数据分析
  • 网站桥页怎么找整站排名服务
  • 信誉最好的20个网投网站百度seo排名优
  • 做网站初中seo快速排名软件
  • 重庆建筑网站公司官网怎么做
  • 网站建设什么意思石家庄市人民政府官网
  • 浦东做网站青岛网络工程优化