springboot中处理mybatis返回Map时key值的大小写
发表于:2025-01-25 作者:千家信息网编辑
千家信息网最后更新 2025年01月25日,为了统一不同数据库返回key值大小写不一致的问题,特自定义ObjectWrapperFactory来做统一的处理1,首先自定义MapWrapper/** * 将Map的key全部转换为小写 * */p
千家信息网最后更新 2025年01月25日springboot中处理mybatis返回Map时key值的大小写
为了统一不同数据库返回key值大小写不一致的问题,特自定义ObjectWrapperFactory来做统一的处理
1,首先自定义MapWrapper
/** * 将Map的key全部转换为小写 * */public class MapKeyLowerWrapper extends MapWrapper { public MapKeyLowerWrapper(MetaObject metaObject, Map map) { super(metaObject, map); } @Override public String findProperty(String name, boolean useCamelCaseMapping) { return name==null?"":name.toLowerCase() ; }}
2,自定义ObjectWrapperFactory
mybatis默认的ObjectWrapperFactory
public class DefaultObjectWrapperFactory implements ObjectWrapperFactory { public boolean hasWrapperFor(Object object) { return false; } public ObjectWrapper getWrapperFor(MetaObject metaObject, Object object) { throw new ReflectionException( "The DefaultObjectWrapperFactory should never be called to provide an ObjectWrapper."); }}
我们自定义的如下:
public class MapWrapperFactory implements ObjectWrapperFactory { @Override public boolean hasWrapperFor(Object object) { return object != null && object instanceof Map; } @Override public ObjectWrapper getWrapperFor(MetaObject metaObject, Object object) { return new MapKeyLowerWrapper(metaObject, (Map) object); }}
3,在mybatis的配置中添加 MapWrapperFactory 的配置
@Bean(name = "sqlSessionFactory")@ConditionalOnBean(name = "dataSource")public SqlSessionFactory sqlSessionFactoryBean(@Qualifier("dataSource") DataSource dataSource) { SqlSessionFactoryBean bean = new SqlSessionFactoryBean(); bean.setObjectWrapperFactory(new MapWrapperFactory()); bean.setDataSource(dataSource); // 添加XML目录 ResourcePatternResolver resolver = new PathMatchingResourcePatternResolver(); try { bean.setMapperLocations(resolver.getResources("classpath*:com/ultrapower/ioss/**/mapper/**/*.xml")); return bean.getObject(); } catch (Exception e) { e.printStackTrace(); throw new RuntimeException(e); }}@Bean("sqlSessionTemplate")@ConditionalOnBean(name = "sqlSessionFactory")public SqlSessionTemplate sqlSessionTemplate( @Qualifier("sqlSessionFactory") SqlSessionFactory sqlSessionFactory) { return new SqlSessionTemplate(sqlSessionFactory);}@ConditionalOnBean(name = "dataSource")@Bean(name = "transactionManager")public PlatformTransactionManager transactionManager(@Qualifier("dataSource") DataSource dataSource) { DataSourceTransactionManager dataSourceTransactionManager = new DataSourceTransactionManager(dataSource); return dataSourceTransactionManager;}
统一
配置
大小
处理
不同
一致
小写
数据
数据库
目录
问题
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
mcu功能测试软件开发
安卓数据库框架re
网络安全考核题目
石家庄节能软件开发费用
ipab连接不到服务器
全加固服务器成交公告
网络技术总监岗位职责
美国思博伦 国产网络安全检测
网络技术开发记录
达梦数据库段的分配
计算机网络技术的前十公司
吉首网络安全座谈会
装完服务器系统后弹出运行框
退役服务器
怎么样备份文件放到数据库
江苏计算机软件开发定做
互联网科技旅游服务
简述工业控制网络技术
网络安全贯彻落实工作
网络安全 世纪佳缘
广东大数据软件开发价格表
网络安全专业学习什么
昆明农职院校计算机网络技术
路由器和服务器搭建
cma 认证网络安全项目
聊天信息用数据库怎么存储
邮储银行软件开发笔试题
信誉好的浪潮服务器经销
涪陵区媒体网络技术服务供应商家
Java服务器漏洞修复工具