最近有个任务:根据查询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根据数据动态生成对象的更多相关文章

  1. WPF 动态生成对象属性 (dynamic)

    原文:WPF 动态生成对象属性 (dynamic) 项目中列行的数据 都需要动态生成 所以考虑到对象绑定  可需要一个动态生成属性的意思 缺点 加载速度会慢 很明显的慢 解决办法 尽量减轻动态属性的量 ...

  2. 如何用asp.net MVC框架、highChart库从sql server数据库获取数据动态生成柱状图

    如何用asp.net MVC框架.highChart库从sql server数据库获取数据动态生成柱状图?效果大概是这样的,如图: 请问大侠这个这么实现呢?

  3. python-根据字符串动态生成对象eval

    # -*- coding: utf-8 -*- stock1={ 'stockName':"沈阳机床", ", 'averagePrice_yesterday':34.0 ...

  4. C++ 动态生成对象

    1.啰嗦一下 说起C++,很多人都觉着难学,其实我也是这么觉着的,在这个移动端火到爆的时代,我都想改行了,移动端做东西那都是现有的第三方库,拿来就可以用,而且稳定性好,开发速度快,而且最关键的是出东西 ...

  5. 利用runtime动态生成对象?

    利用runtime我们能够动态生成对象.属性.方法这特性 假定我们要动态生成DYViewController,并为它创建属性propertyName 1)对象名 NSString *class = @ ...

  6. jsp页面根据json数据动态生成table

    根据需求由于不同的表要在同一个jsp展示,点击某个表名便显示某张表内容,对于java后台传给jsp页面的json形式的数据是怎么动态生成table的呢? 找了好久,终于找到某位前辈的答案,在此表示衷心 ...

  7. 根据xml配置使用反射动态生成对象

    web.xml <?xml version="1.0" encoding="UTF-8"?> <web-app xmlns="htt ...

  8. js将json数据动态生成表格

    今天开发中遇到需要展示动态数据的问题, 具体要求是后端传来的json字符串,要在前端页面以table表格的形式展示, 其实没啥难的,就是拼接table标签,纯属体力活,于是自己写了个呆萌,保存起来,以 ...

  9. Winfrom treeview 如何从多个数据表中获取数据动态生成

    本文转载:http://www.cnblogs.com/VincentLuo/archive/2008/03/29/1128987.html 在 汪洋怡舟的这篇文章中[http://www.cnblo ...

随机推荐

  1. Shell 起停脚本 专题

    To list any process listening to the port 8080: lsof -i:8080To kill any process listening to the por ...

  2. SwaggerUI--SosoApi

    1.SwaggerUI是什么? Swagger UI是一款RESTFUL接口的文档在线自动生成+功能测试功能软件. Swagger-UI 的官方地址:http://swagger.io/ Github ...

  3. Android 打造任意层级树形控件 考验你的数据结构和设计

    转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/40212367,本文出自:[张鸿洋的博客] 1.概述 大家在项目中或多或少的可能会 ...

  4. 【转】jquery-easyui中datagrid的单击删除此行

    最近在easyui的项目开发,easyui封装了许多方法,用起来很方便,但同时也遇到了不少的问题. 如果在datagrid中直接将index传给easyui自带的deletRow方法来删除当前点击行, ...

  5. admin-handlers.go

    package],,) ],,) ],,) ],,) ],,) ])     if err == redis.Nil {         http.NotFound(w, r)     } else ...

  6. 使用limit查询的同时取得总的记录数:SQL_CALC_FOUND_ROWS和FOUND_ROWS()

    通常我们都用如下的sql来进行列表 SELECT COUNT(*) FROM users WHERE name LIKE 'a%';SELECT name, email FROM users WHER ...

  7. 浅析Django之session与cookie

    浅析Django之session与cookie 1 session与cookie概述 原理: 由于HTTP协议是无状态,无连接的,当用户发起网路请求时,需要服务端能标识用户ID,用以存储用户相关信息, ...

  8. turtle文库 ——python

    本文将会为您介绍关于python--turtle库函数,学会这个库函数,会有很多让你意想不到的事情发生哦! 我也也会为你们,简单的编写几个代码,让你们看一下turtle函数的魅力 Turtle库是Py ...

  9. 带你由浅入深探索webpack4(二)

    在前一篇文章已经介绍了webpack4从入门到一些核心常用的用法,大家可以从上一篇文章看起.带你由浅入深探索webpack4(一) 接着上一章,接下来我们会继续探讨webpack4中的各种实用用法,让 ...

  10. Java核心技术梳理-集合

    一.前言 在日常开发中,我们经常会碰到需要在运行时才知道对象个数的情况,这种情况不能使用数组,因为数组是固定数量的,这个时候我们就会使用集合,因为集合可以存储数量不确定的对象. 集合类是特别有用的工具 ...