JeeSite | 保存信息修改记录续
接上一篇 JeeSite | 保存信息修改记录
遗留问题
上篇文章中遗留了一个问题,就是为了要关联类属性与注释,注释与字典的地方使用了两个 map 来逐个添加了相关的信息,如下所示:
Map<String, String> mapField = new HashMap<String, String>() {{
// 类中的属性,属性对应的中文
put("sex","性别");
}};
Map<String, String> mapDict = new HashMap<String, String>() {{
// 属性对应的中文,在JeeSite中字典的描述
put("性别", "SEX");
}};
在例子中,这里只给出了一个字段,其实这里有非常多的字段和字典需要关联,毕竟一个表不可能只有一个字段。当表结构发生改变后,这些“硬编码”的表字段和字典的两个 map 也需要相应的修改,反复的增加和修改这部分内容费时费力还容易错,那么解决的办法就是使用 JeeSite 系统中提供的两个表 gen_table 和 gen_table_column。
表介绍
gen_table 和 gen_table_column 是主从表(主表和明细表),一个用于记录表,一个用于记录表中的列,然后它们的关联关系如下:
gen_table.id = gen_table_column.gen_table_id
在 gen_table 中保存了表名对应的类名,在 gen_table_column 表中保存了表字段对应的注释和对应的 Java 类属性,有了这几部分就可以通过 类名 来获取注释和类属性了。
添加获取函数
操作 gen_table 和 gen_table_column 的 Java 文件分别是 GenTableService.java、GenTableDao.java 和 GenTableColumnDao.java,还包括两个MyBatis用的 GenTableDao.xml 和 GenTableColumnDao.xml 文件。分别修改这几个文件。
在 GenTableService.java 中增加如下代码:
/**
* 通过类名获取对应的GenTable对象
* @param className 类名
* @return GenTable对象
*/
public GenTable getTableByClass(String className) {
GenTable gt = genTableDao.getTableByClass(className);
return gt;
}
/**
* 通过表id获取表中的列
* @param tableId 表id
* @return 表中的列
*/
public List<GenTableColumn> getColumnByTable(String tableId) {
List<GenTableColumn> gtcList = genTableColumnDao.getColumnByTable(tableId);
return gtcList;
}
在 GenTableDao.java 中增加上面第一个方法的定义:
GenTable getTableByClass(String className);
在 GenTableColumnDao.java 中增加上面第二个方法的定义:
GenTable getTableByClass(String className);
在 GenTableDao.xml 中增加如下查询代码:
<!-- 通过类名获得表名 -->
<select id="getTableByClass" resultType="GenTable">
SELECT
<include refid="genTableColumns"/>
FROM gen_table a
<include refid="genTableJoins"/>
WHERE a.del_flag = 0
AND a.class_name = #{className}
</select>
在 GenTableColumnDao.xml 中增加如下的查询代码:
<!-- 通过表id获得表列 -->
<select id="getColumnByTable" resultType="GenTableColumn">
SELECT
<include refid="genTableColumnColumns"/>
FROM gen_table_column a
<include refid="genTableColumnJoins"/>
WHERE a.del_flag = 0
AND a.gen_table_id = #{tableId}
</select>
注:在 JeeSite 中的分层中,所有的请求都在 Controller 层中处理,然后要进行业务处理的操作,都会再调用对应的 Service 层,Service 层再去调用相应的 Dao 层完成数据的读取和写入,Dao 层通过 MyBatis 中的 SQL 语句来获取相应的数据后逐层的返回。
获得对象中的属性对应的注释及字典
有了上面的定义就可以在 Controller 中来获取类属性对应的注释及字典了。代码如下:
// 根据类名获得对应的表信息
GenTable genTable = genTableService.getTableByClass("HousingResource");
if ( genTable == null ) {
return "";
}
// 根据表id获取表相应的字段信息
List<GenTableColumn> columnList = genTableService.getColumnByTable(genTable.getId());
if ( columnList == null ) {
return "";
}
Map<String, String> mapField = new HashMap<String, String>();
Map<String, String> mapDict = new HashMap<String, String>();
// 获得字段对应的Java属性和字段注释
for( GenTableColumn gtc : columnList ) {
mapField.put(gtc.getJavaField(), gtc.getComments());
}
// 获得字段对应的注释和对应的字典
for ( GenTableColumn gtc : columnList ) {
if ( StringUtils.isNotEmpty(gtc.getDictType())
&& StringUtils.isNotBlank(gtc.getDictType()) ) {
mapDict.put(gtc.getComments(), gtc.getDictType());
}
}
到此,对于上篇文章遗留的问题就修改完成了,那么以后只要表结构改变了,只要在 JeeSite 中的“业务表配置”下,重新将表添加一次,这样就可以免去每次都修改代码的麻烦了。
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 用好Jackson,操作Json节省一半时间
- Java|类的继承中两种错误的解决方式 |案例介绍
- 3分钟短文 | PHP时不时蹦出这串神秘字符,有认识的吗?
- 五分钟看懂 Nginx 负载均衡
- 干掉公式 —— numpy 就该这么学
- 全面解析YOLO V4网络结构
- 刺激!一行代码即可导出所有浏览记录
- 你不知道的 node 爬虫原来这么简单
- 带货直播系统源码中,商品详情页是如何搭建起来的
- 基于飞桨复现CVPR 2020 GhostNet的全程解析
- 【即时通信IM】红包消息如何构建?
- YOLOv4损失函数全面解析
- Pandas进阶修炼120题,给你深度和广度的船新体验
- 5万字、97 张图总结操作系统核心知识点
- C++核心准则CP.100:不要使用无锁编程方式,除非绝对必要