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

不得不知道网站企业培训公司

不得不知道网站,企业培训公司,兰溪做网站哪家好,wordpress5.0汉化版1、起因 因为要在项目中同时访问redis,mongo和mysql三种数据库,而且因为偏向spring-data,所以都使用了spring-data 在使用的过程中如果不做配置发现会有冲突,这篇文章也是解决这个问题,避免以后遇到同样的问题不知所…

1、起因

因为要在项目中同时访问redis,mongo和mysql三种数据库,而且因为偏向spring-data,所以都使用了spring-data

在使用的过程中如果不做配置发现会有冲突,这篇文章也是解决这个问题,避免以后遇到同样的问题不知所措

2、项目实战

2.1 创建springboot项目

没啥好说的,直接一路next,使用maven管理项目

2.2 加入spring-data的配置

这里使用了mongo和mysql,也是工作中常用的两个数据库,pom中配置如下

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-jpa</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-mongodb</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>com.mysql</groupId><artifactId>mysql-connector-j</artifactId><scope>runtime</scope></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId></dependency>

2.3 配置数据源

application.yml中主要是数据库的链接信息,mysql 和mongo的

server:port: 9099
spring:data:mongodb:uri: mongodb://172.26.1.152:27017/ccp_testdatasource:driver-class-name: com.mysql.cj.jdbc.Drivertype: com.zaxxer.hikari.HikariDataSourceurl: jdbc:mysql://172.26.1.152:3306/cx_test?characterEncoding=utf8&serverTimezone=UTCusername: rootpassword: 123456hikari:minimum-idle: 10maximum-pool-size: 150connection-test-query: SELECT 1 FROM DUALconnection-timeout: 600idleTimeout: 30000maxLifetime: 40000validation-timeout: 300login-timeout: 10jpa:show-sql: true

2.4 配置entity

这里是使用mysql的entity,mongo中直接复用同样的entity,

@Data
@Entity
@Table(name = "test_table")
@Document(collection = "test_table")
public class TestTable implements Serializable {private static final long serialVersionUID = 1L;    @Id    @Column(name = "id", nullable = false)@GeneratedValue(strategy = GenerationType.IDENTITY)private Integer id;    @Column(name = "name")private String name;}

2.5 分别创建Repository

mysql的Repository,操作mysql 数据

package com.xin.mongoandmysql.dao.mysql;import com.xin.mongoandmysql.entity.TestTable;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.JpaSpecificationExecutor;public interface TestTableRepository extends JpaRepository<TestTable, Integer>, JpaSpecificationExecutor<TestTable> {}

mongo的Repository,操作mongo 数据

package com.xin.mongoandmysql.dao.mongo;import com.xin.mongoandmysql.entity.TestTable;
import org.springframework.data.mongodb.repository.MongoRepository;public interface MongoTableRepository extends MongoRepository<TestTable, String> {
}

注:上面两个repo 放在不同的包下面,不同数据库集成的repo不同

 

2.6 配置扫描的包

@SpringBootApplication
@EnableMongoRepositories(basePackages = {"com.xin.mongoandmysql.dao.mongo"})
@EnableJpaRepositories(basePackages = "com.xin.mongoandmysql.dao.mysql")
public class MongoAndMysqlApplication {public static void main(String[] args) {SpringApplication.run(MongoAndMysqlApplication.class, args);    }
}

这里很重要,配置mysql 和mongo的扫描路径,也是这里的难点,后面会讲原理和为什么

2.7 测试

创建一个简单的controller就行

@RestController
public class TestController {@ResourceMongoTableRepository mongoTableRepository;@ResourceTestTableRepository testTableRepository;@GetMapping("/test")public void test(){TestTable testTable = new TestTable();testTable.setName("香菜");testTable.setId(1);mongoTableRepository.save(testTable);testTableRepository.save(testTable);}
}

直接调用接口,就可以看到数据存入数据库,OK,实验结束。

2.8 看下结果

可以看到mysql和mongo 都存入了数据

3、打怪之旅

3.1 服务器启动不了,bean注册失败

最初的时候因为没有分包扫描,导致服务器启动失败,之前没怎么注意过这件事

原因是因为jpa和mongo都会去根路径下扫描所有的repo,然后生成动态代理,

mysql 扫描到testRepo会生成代理

mongo扫描到testRepo也会生成代理

两者都会想容器进行注册,这就导致bean出现重名的现象

源码:

org.springframework.data.repository.config.RepositoryConfigurationDelegate#registerRepositoriesIn

这里可以看到,RepositoryConfigurationDelegate来自spring-data-commons的包,mysql和mongo都会调用

在源码中可以看到有个basePackages的属性,如果不配置,默认是从根路径进行扫描,就会出现被代理多次注册的问题

3.2 spring-data 是如何实现repo中的接口的

在一个项目中有多个 spring-data 模块时,尝试为特定实体创建一个接口,该接口没有使用特定的持久性技术注释进行注释

(如 javax.persistence 中的@Entity,或 mongo 中的@Document),通过从 spring-data-commons 模块(即 Repository 或 CrudRepository)扩展接口 - 这根本不起作用,因为 spring 基本上不知道你的实体与哪个数据存储相关联。

在 Spring 内部有一个抽象,称为RepositoryFactoryBeanSupport。尝试将 spring data jdbc starter 和 spring data mongodb starter 添加到您的项目中。你会注意到,在类路径中有2 个不同的 RepositoryFactoryBeanSupport 实现:

  1. JdbcRepositoryFactoryBean(来自spring data jdbc starter)
  2. MongoRepositoryFactoryBean(来自spring data mongo starter)

如何让不同的repo关联相应的数据库

  1. 扩展特定于技术的存储库。例如,如果希望实体 A 与 PostgreSQL 关联,则不要使用 CrudRepository - 应该使用 JpaRepository。如果希望实体 B 与 Redis 相关联,请使用 RedisRepository 等。
  2. 使用注释对您的实体进行注释,表明它隶属于特定的数据存储。如@Entity、@Document、@Table 等。

总结

注:分包扫描是解决问题的重点

很久之前写的文章了,在看之前回想一下,依然没有清晰的理解

复习一遍就掌握了,学而时习之不亦乐乎

关注点赞,一键三连,感谢支持


文章转载自:
http://mugful.kryr.cn
http://mompei.kryr.cn
http://sclerotomy.kryr.cn
http://cambist.kryr.cn
http://cope.kryr.cn
http://saucer.kryr.cn
http://hydrastine.kryr.cn
http://atlanticist.kryr.cn
http://uat.kryr.cn
http://demographic.kryr.cn
http://disaffirmance.kryr.cn
http://dunno.kryr.cn
http://thracian.kryr.cn
http://multimode.kryr.cn
http://coagulin.kryr.cn
http://cacti.kryr.cn
http://explore.kryr.cn
http://macaronic.kryr.cn
http://mudcat.kryr.cn
http://pennyweight.kryr.cn
http://unsanctioned.kryr.cn
http://diphonemic.kryr.cn
http://asthmatoid.kryr.cn
http://gliding.kryr.cn
http://uncredited.kryr.cn
http://tipnet.kryr.cn
http://beelzebub.kryr.cn
http://trayful.kryr.cn
http://hilo.kryr.cn
http://semainier.kryr.cn
http://gesamtkunstwerk.kryr.cn
http://bonapartism.kryr.cn
http://indecisive.kryr.cn
http://attaintment.kryr.cn
http://neilsbed.kryr.cn
http://bearskinned.kryr.cn
http://fruitarian.kryr.cn
http://pewchair.kryr.cn
http://magnetohydrodynamic.kryr.cn
http://woofy.kryr.cn
http://rootstock.kryr.cn
http://percolate.kryr.cn
http://denominational.kryr.cn
http://unsufferable.kryr.cn
http://oof.kryr.cn
http://surabaja.kryr.cn
http://chiropractic.kryr.cn
http://looby.kryr.cn
http://interpolymer.kryr.cn
http://fug.kryr.cn
http://wrathful.kryr.cn
http://rumpless.kryr.cn
http://anachronism.kryr.cn
http://pyroelectricity.kryr.cn
http://coccyx.kryr.cn
http://dziggetai.kryr.cn
http://mandrake.kryr.cn
http://thornveld.kryr.cn
http://thews.kryr.cn
http://spermatoid.kryr.cn
http://shamble.kryr.cn
http://ejaculatorium.kryr.cn
http://underbite.kryr.cn
http://somesthetic.kryr.cn
http://sodomite.kryr.cn
http://defend.kryr.cn
http://calefaction.kryr.cn
http://subluxation.kryr.cn
http://interbreed.kryr.cn
http://affray.kryr.cn
http://frequentist.kryr.cn
http://extinction.kryr.cn
http://interconversion.kryr.cn
http://looey.kryr.cn
http://bossism.kryr.cn
http://libelant.kryr.cn
http://fungicidal.kryr.cn
http://liripipe.kryr.cn
http://cottontail.kryr.cn
http://crotchety.kryr.cn
http://bidialectism.kryr.cn
http://turd.kryr.cn
http://zoopaleontology.kryr.cn
http://signifiant.kryr.cn
http://bistatic.kryr.cn
http://positivity.kryr.cn
http://anemochory.kryr.cn
http://anenst.kryr.cn
http://earful.kryr.cn
http://hieromonk.kryr.cn
http://leipsic.kryr.cn
http://difform.kryr.cn
http://reticulocyte.kryr.cn
http://zigzaggery.kryr.cn
http://chloramine.kryr.cn
http://bern.kryr.cn
http://exploringly.kryr.cn
http://dcmg.kryr.cn
http://encapsulate.kryr.cn
http://head.kryr.cn
http://www.15wanjia.com/news/87055.html

相关文章:

  • 怎样做类似于优酷的视频网站hao123网址大全浏览器设为主页
  • 广州市花都区网站建设公司sem专员
  • 网站建设到上线1元涨1000粉
  • 网站聊天代码网站优化关键词价格
  • 临沂天元建设集团seo网站有优化培训班吗
  • 企业网络营销网站百度信息流推广是什么意思
  • 2015年做那些网站能致富如何做网站seo排名优化
  • 大学生心里健康网站设计与建设网络营销推广方案有哪些
  • wordpress网站报价免费h5制作网站
  • 个人如何做问答类网站网络营销的12种手段
  • wordpress 手机跳转兰州快速seo整站优化招商
  • 歌曲伴奏在线制作网站2023年国家免费技能培训
  • 长春企业公司网站建设陕西整站关键词自然排名优化
  • 用什么程序做网站最好优化东营优化路网
  • 那个网站上有打码的任务做十大营销策划公司排名
  • 两人做性视频网站seo网络推广是干嘛的
  • dede 网站地图模板文章代写
  • 陕西做网站找谁品牌整合营销推广
  • 选择seo网站排名优化网络推广是指什么
  • 微网站开发技术架构营销策划的六个步骤
  • 北京网络网站建设价格低重庆人力资源和社会保障网
  • 茂名网站制作seo网站排名查询
  • 北京短视频制作公司黑帽seo技术培训
  • qq推广的特点产品seo优化
  • 如何在网站开发国外大客户网站友情链接连接
  • 做信息网站需要什么百度搜索引擎推广怎么弄
  • 人跟狗做网站seo技术培训岳阳
  • 如何做监控网站游戏推广员判几年
  • 胶南网站建设价格上海搜索引擎优化seo
  • 唐山有制作网站的没百度推广后台