Spring整合多个mongoDB服务笔记

本文介绍了在Spring项目中整合多个mongoDB服务的配置过程,并详细解析了@Resource与@Autowired注解的区别。在配置中,通过在dev.properties和mongo.xml中添加新配置,并在service中使用@Resource注入mongoTemplate。文章强调了@Resource在bean注入时的细节,以及在没有指定name和type时,将按名称匹配bean。理解这些注解的用法对于日常开发工作至关重要。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近做老项目部分功能的迁移,由于历史原因该功能与其他部门共用了一套mongoDB,但是我的新项目中已经有了一套自己的mongoDB,所以需要再多加一套配置。

在新增这个mongo配置的过程中,参考老的配置。但是有一个疑惑,为什么只有一个简单的配置,在使用的过程中却可以连接到正确目标服务。直接上代码吧!

maven中添加依赖(因为项目中已经添加了,所以不需要重新添加)

<!-- mongodb java driver -->
        <dependency>
            <groupId>org.mongodb</groupId>
            <artifactId>mongo-java-driver</artifactId>
            <version>3.2.1</version>
        </dependency>
        <!-- Spring data mongodb -->
        <dependency>
            <groupId>org.springframework.data</groupId>
            <artifactId>spring-data-mongodb</artifactId>
            <version>1.8.0.RELEASE</version>
        </dependency>

在dev.properties中新增配置:

#MongoDB
mongo_replica_set=127.0.0.1:27017
mongo_database=test
mongo_username=test01
mongo_password=123456

在mongo.xml中新增配置:

<!-- test mongoDB配置-->
	<mongo:mongo-client id="mongo"
						credentials="${mongo_username}:${mongo_password}@${mongo_database}"
						replica-set="${mongo_replica_set}">
		<mongo:client-options write-concern="SAFE"
							  connect-timeout="1000" />
	</mongo:mongo-client>

	<!-- MongoDbFactory -->
	<mongo:db-factory id="mongoDbFactory" dbname="${mongo_database}" mongo-ref="mongo"/>

	<bean id="mappingContext"
		  class="org.springframework.data.mongodb.core.mapping.MongoMappingContext" />


	<bean id="defaultMongoTypeMapper"
		  class="org.springframework.data.mongodb.core.convert.DefaultMongoTypeMapper">
		<constructor-arg name="typeKey">
			<null />
		</constructor-arg>
	</bean>

	<bean id="mappingMongoConverter"
		  class="org.springframework.data.mongodb.core.convert.MappingMongoConverter">
		<constructor-arg name="mongoDbFactory" ref="mongoDbFactory" />
		<constructor-arg name="mappingContext" ref="mappingContext" />
		<property name="typeMapper" ref="defaultMongoTypeMapper" />
	</bean>

	<bean id="mongoTemplate" class="org.springframework.data.mongodb.core.MongoTemplate">
		<constructor-arg name="mongoDbFactory" ref="mongoDbFactory" />
		<constructor-arg name="mongoConverter" ref="mappingMongoConverter" />
	</bean>

在service中使用的时候,先注入mongoTemplate,方式如下:

@Resource
private MongoTemplate mongoTemplate;

在这里一定要使用@Resource注入(这个注解属于J2EE的),原因在于:

@Resource在bean注入的过程中有以下几个细节:
  1. 如果同时指定了name和type,则从Spring上下文中找到唯一匹配的bean进行注入,找不到则抛出异常
  2. 如果指定了name,则从上下文中查找名称(id)匹配的bean进行注入,找不到则抛出异常
  3. 如果指定了type,则从上下文中找到类型匹配的唯一bean进行注入,找不到或者找到多个,都会抛出异常
  4. 如果既没有指定name,又没有指定type,则自动按照byName方式进行注入;如果没有匹配,则回退为一个原始类型进行匹配,如果匹配则自动注入;

我们默认使用的时候则是按照name去匹配,查找id是mongoTemplate,如果找不到则按type去注入。

@Autowired注解是按照类型(byType)装配依赖对象,默认情况下它要求依赖对象必须存在,如果允许null值,可以设置它的required属性为false。如果我们想使用按照名称(byName)来装配,可以结合@Qualifier注解一起使用,如:

@Autowired
@Qualifier("mongoTemplate")
private MongoTemplate mongoTemplate;

最初的时候忽略了@Resource与@Autowired区别,没想明白都是注入MongoTemplate这个类,只是名字不同,却能正确的指向目标机器。后来看了一下注入方式,恍然大悟!这些之前只在面试的时候才会被问到的问题,在实际工作中还是很有用的!这些技能掌握的层度也就是我们能力的体现!加油~~~

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值