设计思路:

1、首先将字典表的数据以Map的形式进行初始化,key格式为type+"@"+code,value值为正常回显的值,如"ta_sex"+"@"+"1", "男"

2、建立DictAcc注解,code代表是数据库字段还是需要回显的标识,type存储类型如ta_sex

@Target(ElementType.FIELD)

@Retention(RetentionPolicy.RUNTIME)

public @interface DictACC {

public String code();

public String type();

}

3.建立一个类BV,code表示数据库存储的名字,name表示需要回显的名字

public class BV {

public final static String code="code";

public final static String name="name";

}

4.在pojo中字段sex,再建立sex_n表示要回显的字段(_n必须对应)

public class User {

@DictACC(code = BV.code, type = "ta_orgType")

public String orgType="1";

@DictACC(code = BV.name, type = "ta_orgType")

public String orgType_n;

@DictACC(code = BV.code, type = "ta_sex")

public String sex="1";

@DictACC(code = BV.name, type = "ta_sex")

public String sex_n;

public String getOrgType() {

return orgType;

}

public void setOrgType(String orgType) {

this.orgType = orgType;

}

public String getOrgType_n() {

return orgType_n;

}

public void setOrgType_n(String orgType_n) {

this.orgType_n = orgType_n;

}

public String getSex() {

return sex;

}

public void setSex(String sex) {

this.sex = sex;

}

public String getSex_n() {

return sex_n;

}

public void setSex_n(String sex_n) {

this.sex_n = sex_n;

}

}

5.代码如下:map相当与数据库中取出来的数据库字典表

public class MainTest {

public static void main(String[] args) throws IllegalArgumentException, IllegalAccessException {

HashMap map=new HashMap();

map.put("ta_orgType"+"@"+"1", "部门1");

map.put("ta_orgType"+"@"+"2", "部门2");

map.put("ta_orgType"+"@"+"3", "部门3");

map.put("ta_sex"+"@"+"1", "男");

map.put("ta_sex"+"@"+"2", "女");

User user=new User();

User user1=new User();

List userList=new ArrayList();

userList.add(user);

userList.add(user1);

Doaction.fill(userList,map);

for (int i = 0; i < userList.size(); i++) {

System.out.println(userList.get(0).getOrgType_n());

}

}

}

6.利用反射完成对sex_n等赋值

public class Doaction {

public static void fill(List pojoList, HashMap dictmap)

throws IllegalArgumentException, IllegalAccessException {

Map> map = getDictMap(pojoList.get(0));

Map codeMap = map.get("codeMap");

Map nameMap = map.get("nameMap");

for (T pojo:pojoList) {

fillname(pojo, codeMap, nameMap, dictmap);

}

}

/**

* 获取带DictACC字典注解的字段,并拼接成Map

* @param t

* @return

*/

public static Map> getDictMap(T t) {

//字典code值组成的Map

Map codeMap = new HashMap();

//需要从code值转成value组成的Map

Map nameMap = new HashMap();

List fieldlist =new ArrayList();

//获取父类的所有field

fieldlist.addAll(Arrays.asList(t.getClass().getSuperclass().getDeclaredFields()));

//获取本类的所有field

fieldlist.addAll(Arrays.asList(t.getClass().getDeclaredFields()));

for (Field field : fieldlist) {

if (field.getAnnotation(DictACC.class) != null) {

DictACC ann = field.getAnnotation(DictACC.class);

if (ann.code().equals(BV.code)) {

codeMap.put(ann.type() + "@" + field.getName(), field);

} else if (ann.code().equals(BV.name)) {

nameMap.put(ann.type() + "@" + field.getName(), field);

}

}

}

Map> map = new HashMap>();

map.put("codeMap", codeMap);

map.put("nameMap", nameMap);

return map;

}

public static void fillname(T t, Map codeMap,

Map nameMap, HashMap dictmap)

throws IllegalArgumentException, IllegalAccessException {

for (Entry entry : nameMap.entrySet()) {

//获取codekey

String codeKey = entry.getKey().substring(0,

entry.getKey().length() - 2);

if (codeMap.get(codeKey) != null) {

Field field = codeMap.get(codeKey);

//获取code的值

String value = String.valueOf(field.get(t));

String targetKey = codeKey.split("@")[0] + "@" + value;

if (dictmap.containsKey(targetKey)) {

//从字典表获取那么中应该存的值

String targetValue = dictmap.get(targetKey);

Field targetField = entry.getValue();

targetField.setAccessible(true);

//给name赋值

targetField.set(t, targetValue);

}

}

}

}

}

java获取字典表数据,利用注解完成字典表数据对应相关推荐

  1. java 读取 excel 注释_java利用注解实现简单的excel数据读取

    搜索热词 实现工具类 利用注解实现简单的excel数据读取,利用注解对类的属性和excel中的表头映射,使用Apache的poi就不用在业务代码中涉及row,rows这些属性了. 定义注解: @Ret ...

  2. ios 数组中的字典排序_利用数组和字典,实现按指定规则的排序

    大家好,今日我们继续讲解数组与字典解决方案,今日讲解第47讲:利用字典和数组,实现按指定规则的排序.随着字典讲解的深入,我们发现字典真的很神奇,在VBA代码中,给人以十分清爽的感觉,在这套数组与字典解 ...

  3. 处理DataFrame数据——利用Groupby函数分类汇总数据并转为矩阵

    问题 我的手头有35万条数据,包含三个属性:时间.数量和ID.我现在需要以时间.ID分类,对数量进行求和统计(分类汇总):然后以time列为行(x轴),ID为列(y轴),num为值建立矩阵. 读取数据 ...

  4. java 获取百度云盘图片_java 利用百度云识别图片文字

    一.百度云使用步骤 1.进入https://console.bce.baidu.com/#/index/overview 登录百度云账号.百度所有账号都是通用的,可以直接利用百度的其他账号(百度网盘. ...

  5. java获取类与方法的注解、注释

    第一.获取注解 @Test(description = "获取类.方法注解") public void test(){//类注解信息Annotation[] annotations ...

  6. java 获取文件名长度_利用Java文件类File的方法,获取磁盘文件的文件名、长度、大小等特性...

    利用Java文件类File的方法,获取磁盘文件的文件名.长度.大小等特性. 如题,大神们谁可以编写一个这样的java程序?     happy530755 | 浏览 1482 次 |举报 我 ...

  7. 不小心删除数据--利用MySQL的binlog恢复数据

    MySQL Binary Log也就是常说的bin-log, ,是mysql执行改动产生的二进制日志文件,其主要作用有两个: * 数据回复 * 主从数据库.用于slave端执行增删改,保持与maste ...

  8. python字典数组排序sorted_Python利用sorted进行字典排序

    一.排序算法 排序也是在程序中经常用到的算法.无论使用冒泡排序还是快速排序,排序的核心是比较两个元素的大小.如果是数字,我们可以直接比较,但如果是字符串或者两个dict呢?直接比较数学上的大小是没有意 ...

  9. Python语言学习:利用sorted对字典按照value进行递减排序,输出列表,并给定排名索引,组成新字典输出

    Python语言学习:利用sorted对字典按照value进行递减排序,输出列表,并给定排名索引,组成新字典输出 目录 利用sorted对字典按照value进行递增排序,输出列表,并给定排名索引,组成 ...

  10. 数据权限框架:一个实现数据权限与业务模块完全分离,让数据权限变成独立功能模块的数据权限框架

    meng框架 介绍 meng框架是一个实现了行数据权限和列数据权限的数据权限框架: meng框架能让数据权限变成一个独立的功能模块,与业务模块完全分离,在已经实现的业务逻辑中添加数据权限不需要对原来的 ...

最新文章

  1. Windows 10将为大型企业提供订阅型服务
  2. C++ STL 基本使用Win32 版
  3. GitHub 项目 增加成员
  4. [转]tomcat部署与Context
  5. forge开发_使用Forge,WildFly Swarm和Arquillian开发微服务
  6. 程序员c语言简历,程序员的简历该怎么写?当然是程序!
  7. matlab中弹性碰撞课程设计,完全弹性碰撞matlab.doc
  8. 面试Java岗位时,总被面试题困扰,分享企业爱用的面试题
  9. Cron 定时任务表达式
  10. 使用C#开发纽曼USB来电通来电弹屏客户端小结
  11. 关于冒险岛,8090的不二游戏
  12. .NET 4.0 Interop新特性ICustomQueryInterface
  13. 计算机突然断电 硬盘,电脑突然断电对硬盘有影响吗 保护电脑硬盘方法【详解】...
  14. MySQL百万数据量如何快速查询。求教
  15. net use 访问远程电脑
  16. 新标准大学英语综合教程2(第二版)unit1答案截图
  17. 从QuickTime到Beats:回顾苹果历史上的音乐传奇
  18. 使用 ImageMagick 制作电影海报封面效果的照片
  19. 操作系统--内存管理
  20. 【无服务器架构】openwhisk 经典使用案例

热门文章

  1. 全球最快下载工具 XDM
  2. (转)架构师害怕程序员知道的十项技能
  3. 无线投影仪服务器设置方法,无线投影仪怎么连接,看过教程,原来操作这么简单!...
  4. 家乡主题html模板,html+css模板 我的家乡有模板
  5. 新闻发布系统数据库设计
  6. 计算机汇编语言编程教程,《汇编语言程序设计教程》.pdf
  7. JavaSwing+SQL Server实现网上购物系统
  8. android远程桌面工具下载,Android远程桌面助手
  9. 如何卸载mingw_MinGW和MSYS的自动安装
  10. html开网站弹窗代码大全,JS弹出窗口代码大全(详细整理)