博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[Java 基础]ResultSet 指定field映射到Pojo对象的Map
阅读量:7191 次
发布时间:2019-06-29

本文共 3134 字,大约阅读时间需要 10 分钟。

现在有一个需求,mysql查询记录映射到List<pojo>中,其中pojo某个字段是Map类型,需要将查询记录中这列映射到Map中,否则默认会当作String映射,以下为当前代码:

public List
mapRersultSetToObject(ResultSet rs, Class outputClass) { List
outputList = null; try { // make sure resultset is not null if (rs != null) { // check if outputClass has 'Entity' annotation if (outputClass.isAnnotationPresent(Entity.class)) { // get the resultset metadata ResultSetMetaData rsmd = rs.getMetaData(); // get all the attributes of outputClass Field[] fields = outputClass.getDeclaredFields(); while (rs.next()) { T bean = (T) outputClass.newInstance(); for (int _iterator = 0; _iterator < rsmd.getColumnCount(); _iterator++) { // getting the SQL column name String columnName = rsmd.getColumnName(_iterator + 1); // reading the value of the SQL column Object columnValue = rs.getObject(_iterator + 1); // iterating over outputClass attributes to check if // any attribute has 'Column' annotation with // matching 'name' value for (Field field : fields) { if (field.isAnnotationPresent(Column.class)) { Column column = field.getAnnotation(Column.class); if (column.name().equalsIgnoreCase(columnName) && columnValue != null) { BeanUtils.setProperty(bean, field.getName(), columnValue); break; } } } } if (outputList == null) { outputList = new ArrayList
(); } outputList.add(bean); } } else { // throw some error } } else { return null; } }

解决方案,如果设置属性时每次都检查字段类型,效率会比较低,通过发生异常捕获,然后再转化的方式,如下代码所示:

if (column.name().equalsIgnoreCase(columnName) && columnValue != null) {                                        try{                                            BeanUtils.setProperty(bean, field.getName(), columnValue);                                        }catch (ConversionException exception){                                            if(field.getType().equals(Map.class)){                                                BeanUtils.setProperty(bean, field.getName(), JSON.parse(String.valueOf(columnValue)));                                            }                                        }                                        break;                                    }

 

转载于:https://www.cnblogs.com/zhengwangzw/p/10561163.html

你可能感兴趣的文章
解决TIME_WAIT过多造成的问题
查看>>
mysql 主从同步故障解决 Error 'Row size too large (> 8126).
查看>>
16位纯数字MD5
查看>>
腾讯面试
查看>>
数据备份就用多备份
查看>>
企业如何进行IT基础设施规划
查看>>
我的友情链接
查看>>
iOS面试题第一波
查看>>
在centos中安装puppet和安装过程的一些错误解决
查看>>
html元素
查看>>
使用kaptcha生成验证码
查看>>
Maven学习总结(四)——Maven核心概念
查看>>
python 连接mongodb ,并将EXCEL文档导入mongodb
查看>>
第三节 在shell脚本中进行for循环
查看>>
Java Script 中定义对象的几种方式
查看>>
mysql编译安装完成后,启动时报错The server quit without updating PID file
查看>>
MySQL 错误总结续
查看>>
Nginx并发连接限制
查看>>
BGP的状态
查看>>
javascript声明二维数组
查看>>