由于习惯了.net环境下的DataTable对象的方便和强大,遗憾的是JAVA下没有如此强大的对象支持。在网上找了好久都没有发现自己满意且能满足当前应用需求的实现,于是决定自己实现一套。我现在需要用JAVA实现对几类数据表的动态查询、汇总、计算,具体的需求如下:
1. 保存由数据库查询出来的二维数据,并支持双向循环获取数据内容,支持保存数据列的数据类型。
2. 支持基于查询语句获取数据子集,即基于内存执行数据过滤和计算。
3. 支持基于Datatable对象对已取得数据进行分组汇总并返回汇总后的结果,支持Distinct操作。
4. 支持常见的基于列的数据汇总(最大值、最小值、平均值等)
下图为基本程序结构说明图:
以上各类功能说明:
DataTable:
我们要实现的目标对象,其包括一组二维表的存储结构和基于二维表的一组扩展方法实现。
DataColumn:
数据列定义对象,包括列名、数据类型等相关内容的定义。
DataRow
数据行对象,对应于一个DataTable的DataColumn对象集合,保存一组对应于列定义的数据内容。
DataColumnCollection
数据列集合对象
DataRowCollection
数据行集合对象
接下来分别定义以上对象的结构
DataRow对象
DataColumn对象
DataTable 对象
以上省略了DataRowCollection和DataColumnCollection的结构说明,这两个类是继承于List接口的一组实现。下一篇我们将开始编写这几个对象的代码。