cglib根据数据动态生成对象
最近有个任务:根据查询SQL直接导出报表
实现关键是,怎么根据sql查询的数据动态生成对象列表,想到Cglib动态代理实现
废话少说,上代码:
定义动态生成Java Bean类:
import java.util
import net.sf.cglib.beans.{BeanGenerator, BeanMap}
/**
* 动态Bean生成
*
* @author BarryWang create at 2018/6/19 11:54
* @version 0.0.1
*/
class DynamicBean {
private var `object`: AnyRef = null
private var beanMap: BeanMap = null
def this(fieldTypeMap: util.Map[String, AnyRef]) {
this()
this.`object` = generateObject(fieldTypeMap)
this.beanMap = BeanMap.create(this.`object`)
}
/**
* 生成对象
*
* @param fieldTypeMap 域及类型Map
* @return
*/
private def generateObject(fieldTypeMap: util.Map[String, AnyRef]) = {
val generator = new BeanGenerator
val keySet = fieldTypeMap.keySet
val i = keySet.iterator
while (i.hasNext) {
val key = i.next
generator.addProperty(key, fieldTypeMap.get(key).asInstanceOf[Class[_]])
}
generator.create
}
/**
* 设置域值
*
* @param filedName 域名
* @param value 值
*/
def setValue(filedName: String, value: AnyRef): Unit = {
this.beanMap.put(filedName, value)
}
/**
* 获取域值
*
* @param fieldName 域名
* @return
*/
def getValue(fieldName: String): AnyRef = this.beanMap.get(fieldName)
/**
* 最终对象
*
* @return
*/
def getObject: AnyRef = this.`object`
}
SQL查询数据转对象:
/**
* 根据数据查出数据转成对象列表
* @param database 数据库
* @param querySql 查询SQl
* @return
*/
def getObjectDataList(database: String, querySql: String): ArrayList[Object] = {
println(s"database:${database} sql:${querySql}")
val rs = DataGenerator.getResultSet(database, querySql)
val md = rs.getMetaData
val colCount = md.getColumnCount
val fieldValMap = new JavaHashMap[String, AnyRef]()
for (i <- 0 to colCount - 1) {
fieldValMap.put(underLineToCamel(md.getColumnName(i + 1)), Class.forName("java.lang.String"))
}
// 生成动态 Bean
val returnList = new ArrayList[Object]();
while (rs.next()) {
val objectBean = new DynamicBean(fieldValMap);
for (i <- 0 to colCount - 1) {
val data = getData(md, i+1, rs)
objectBean.setValue(underLineToCamel(md.getColumnName(i + 1)), data)
}
// println(">> " + objectBean.getValue("zhCnName"))
returnList.add(objectBean.getObject)
}
rs.close()
returnList
} def underLineToCamel(name: String): String = {
val result = new StringBuilder
// 快速检查
if (name == null || name.isEmpty) { // 没必要转换
return ""
// } else if (!name.contains("_")) {
// // 不含下划线,仅将首字母小写
// return name.substring(0, 1).toLowerCase() + name.substring(1);
}
// 用下划线将原始字符串分割
val camels = name.split("_")
for (camel <- camels) { // 跳过原始字符串中开头、结尾的下换线或双重下划线
// 处理真正的驼峰片段
if (result.length == 0) { // 第一个驼峰片段,全部字母都小写
result.append(camel.toLowerCase)
}
else { // 其他的驼峰片段,首字母大写
result.append(camel.substring(0, 1).toUpperCase)
result.append(camel.substring(1).toLowerCase)
}
}
result.toString
}
/**
* 从ResultSet取数
* @param md
* @param index
* @param rs
* @return
*/
def getData(md: ResultSetMetaData, index: Int, rs: ResultSet): String = {
md.getColumnType(index) match {
case Types.DECIMAL => {
val value = rs.getBigDecimal(index)
val bigDecimal = value == null match {
case true => "0.0000"
case false => value.setScale(4, RoundingMode.HALF_UP).toString()
}
return bigDecimal
}
case Types.TIMESTAMP =>{
val value = rs.getTimestamp(index)
val timestamp = value == null match {
case true => ""
case false => DateTools.format(new Date(rs.getTimestamp(index).getTime))
}
return timestamp
}
case Types.DATE => {
val value = rs.getDate(index)
val date = value == null match {
case true => ""
case false => DateTools.format(rs.getDate(index), DateTools.DATE_PATTERN)
}
return date
}
case _ => {
val value = rs.getObject(index)
val data = value == null match {
case true => ""
case false => rs.getObject(index).toString
}
return data
}
}
}
cglib根据数据动态生成对象的更多相关文章
- WPF 动态生成对象属性 (dynamic)
原文:WPF 动态生成对象属性 (dynamic) 项目中列行的数据 都需要动态生成 所以考虑到对象绑定 可需要一个动态生成属性的意思 缺点 加载速度会慢 很明显的慢 解决办法 尽量减轻动态属性的量 ...
- 如何用asp.net MVC框架、highChart库从sql server数据库获取数据动态生成柱状图
如何用asp.net MVC框架.highChart库从sql server数据库获取数据动态生成柱状图?效果大概是这样的,如图: 请问大侠这个这么实现呢?
- python-根据字符串动态生成对象eval
# -*- coding: utf-8 -*- stock1={ 'stockName':"沈阳机床", ", 'averagePrice_yesterday':34.0 ...
- C++ 动态生成对象
1.啰嗦一下 说起C++,很多人都觉着难学,其实我也是这么觉着的,在这个移动端火到爆的时代,我都想改行了,移动端做东西那都是现有的第三方库,拿来就可以用,而且稳定性好,开发速度快,而且最关键的是出东西 ...
- 利用runtime动态生成对象?
利用runtime我们能够动态生成对象.属性.方法这特性 假定我们要动态生成DYViewController,并为它创建属性propertyName 1)对象名 NSString *class = @ ...
- jsp页面根据json数据动态生成table
根据需求由于不同的表要在同一个jsp展示,点击某个表名便显示某张表内容,对于java后台传给jsp页面的json形式的数据是怎么动态生成table的呢? 找了好久,终于找到某位前辈的答案,在此表示衷心 ...
- 根据xml配置使用反射动态生成对象
web.xml <?xml version="1.0" encoding="UTF-8"?> <web-app xmlns="htt ...
- js将json数据动态生成表格
今天开发中遇到需要展示动态数据的问题, 具体要求是后端传来的json字符串,要在前端页面以table表格的形式展示, 其实没啥难的,就是拼接table标签,纯属体力活,于是自己写了个呆萌,保存起来,以 ...
- Winfrom treeview 如何从多个数据表中获取数据动态生成
本文转载:http://www.cnblogs.com/VincentLuo/archive/2008/03/29/1128987.html 在 汪洋怡舟的这篇文章中[http://www.cnblo ...
随机推荐
- Linux时间子系统之四:Timer在用户和内核空间流程
用户空间应用中创建一个Timer(alarm/setitimer/POSIX Timer等等),然后程序继续执行: 内核进入创建/设置Timer系统调用,开始计时,在超时后通过何种方式通知用户空间: ...
- 小黄鸡机器人和小I机器人的调用
<?php //---------------------------------聊天小机器人类---------------------------------------------- ...
- 【基于url权限管理 shiro(一)】--基础
只要有用户参与的系统一般都要有权限管理,权限管理实现对用户访问系统的控制,按照安全规则或者安全策略控制用户可以访问而且只能访问自己被授权的资源.权限管理包括用户认证和授权两部分. 用户认证 1.概 ...
- day14_DBUtils学习笔记
一.DBUtils介绍 Apache公司开发的框架. 什么是dbutils?它的作用? DBUtils是java编程中的数据库操作实用工具,小巧简单实用. DBUtils封装了对JDBC的操作 ...
- Android 自定义ViewGroup手把手教你实现ArcMenu
转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/37567907 逛eoe发现这样的UI效果,感觉很不错,后来知道github上有这 ...
- centos7系统日志时间与系统时间相差8小时
场景:当我们修改完系统时间的时区后,我们去查看我们的系统日志的时间发现时区还是在之前的系统时间时区. [root@vp-n ~]# ls -l /etc/localtime lrwxrwxrwx 1 ...
- windows server 2012 R2汉化 -- 玩转Microsoft Azure
Microsoft Azure 试用版小试牛刀 首先需要申请一个账号获得试用权 我这里是1元免费试用, 进入后就可以创建自己的虚拟机及数据库 在这里先说创建的windows server 2012 R ...
- Python ymal 模块和configparser
ymal : 是一种config文件 # !/user/bin/python # -*- coding: utf-8 -*- import configparser # 生成一个config文件 (当 ...
- Java注解Retention、Documented、Target的含义
Retention注解 Retention(保留)注解说明,这种类型的注解会被保留到那个阶段. 有三个值: 1.RetentionPolicy.SOURCE -- 这种类型的Annotations只在 ...
- Oracle解锁scott账号
在安装Oracle的最后一步,有一个口令管理的操作,当时忘了给scott账号解锁了(Oracle为程序测试提供的一个普通账户,口令管理中可以对数据库用户设置密码,默认是锁定的).现在想给scott这个 ...