springboot基于SpEL实现mongodb动态查询collection

背景

以往一直在程序中写死的mongodb查询collection,对于频繁改动的mongodb来说,每次更改都要进行代码修改,费时费力还有风险,故而希望使用动态配置的方式来进行collection查询。
以往映射关系如下:
在这里插入图片描述
由于需要动态配置,首先想到将collection信息存储在zookeeper配置中心里(项目组使用zk做配置中心),所以希望使用@Value的形式来获得,但是由于mongdb中Document不支持@Value的相关语法,所以需要使用表达式来动态支持。

SpEL概念

SpEL全称为“Spring Expression Language”,简写为“SpEL”,参考如下spring 官方文档:https://docs.spring.io/spring/docs/3.0.x/reference/expressions.html
基于SpEL实现mongodb动态配置,在网上资料不多,搜索到一篇文章,https://www.jb51.cc/spring/431546.html,下图为资料中内容
在这里插入图片描述

下图为本人项目中所定义的mongodbconfig
在这里插入图片描述
尝试1.将@Document注释更改为如下所示:

@Document(collection="#{@mongodbTableName.getTableName()}")

但是仍然存在问题,发现程序报错,报错信息如下:

org.springframework.expression.spel.SpelEvaluationException: 
EL1057E: No bean resolver registered in the context to resolve access to bean 'mongodbTableName'

分析bean注册原因,经过检查,bean信息正常,并没有问题,所以分析是表达式问题,进而对表达式进行调整。
尝试2.将@Document注释更改为如下所示:

@Document(collection="#{mongodbTableName.getTableName()}")

结果发现又是新的问题,报错如下:

org.springframework.expression.spel.SpelEvaluationException: EL1007E:(pos 0): Property or field ‘mongodbTableName’ cannot be found on null

怀疑可能还是表达式书写问题,继续调整尝试,
尝试3.将@Document注释更改为如下所示:

@Document(collection="@mongodbTableName.getTableName()")

程序成功运行,初步分析,前面@mongodbTableName去获取spring中对应的bean信息,因为在bean中定义了getTableName(),且返回值为String类型,符合collection要求,实现了配置。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值