Java 核心技术Java Web 核心技术JVM · Java虚拟机原理 · JVM上语言·框架· 生态系统

FastJson中@JSONField注解使用

2017-09-01  本文已影响326人  光剑书架上的书

FastJson中@JSONField注解使用

我们通常使用json格式在服务器之间进行数据传输。

如果json格式数据不符合Java中的标准驼峰式变量定义规则,并且难以理解,这个时候就需要在后台中做二次处理,将数据处理成我们系统中定义的格式。

由于json中的key与bean中的属性不能匹配,通常的转换会出现了部分属性为null的情况。

这种情况,我们可以使用@JSONField。

@JSONField的作用对象:

  1. Field
  2. Setter 和 Getter方法

注:FastJson在进行操作时,是根据getter和setter的方法进行的,并不是依据Field进行。

代码示例:

    @JSONField(name = "reason_clear_time", format = "yyyy-MM-dd HH:mm:ss.S")
    public void setReasonClearTime(Date reasonClearTime) {
        this.reasonClearTime = reasonClearTime;
    }

我们的 POJO 属性字段是reasonClearTime,但是我们需要解析的 json 字符串中的 key 是reason_clear_time, 我们通过使用

@JSONField(name = "reason_clear_time", format = "yyyy-MM-dd HH:mm:ss.S")

实现了映射。

另外,format是数据解析的格式。也就是说,reason_clear_time字段的字符串格式是:

2017-09-01 09:47:57.1

转换成 Date 类型。

json字符串解析代码:

   public void job() {
        String json = PmHitchClient.queryHitchOnline();
        List<Hitch> list = null;
        try {
            list = JSON.parseArray(json, Hitch.class);
            logger.info("PmHitchList ===> {}", list);
            if (null != list && list.size() > 0) {
                for (Hitch h : list) {
                    setGroupDate(h);
                    hitchService.save(h);
                }
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    private void setGroupDate(Hitch h) {
        String groupDate = "W1 2000-01";
        Date catchTime = h.getCatchTime();
        String yearMonth = new SimpleDateFormat("yyyy-MM").format(catchTime);
        Calendar calendar = Calendar.getInstance();
        calendar.setTime(catchTime);
        int weekOfMonth = calendar.get(Calendar.WEEK_OF_MONTH);
        groupDate = "W" + weekOfMonth + " " + yearMonth;
        h.setGroupDate(groupDate);
    }

根据某个字段进行增量更新的代码

@Service
public class HitchServiceImpl implements HitchService{
    @Autowired
    HitchMapper hitchMapper;
    @Override
    public void save(Hitch record) {
        Long hid = record.getHitchId();
        if(null!=hid) {
            Hitch hitch = hitchMapper.selectByHitchId(hid);
            record.setId(hitch.getId());
            if (hitch != null) { // 如果该hitch_id 存在记录,更新之
                hitchMapper.updateByPrimaryKeySelective(record);
            } else {
                hitchMapper.insertSelective(record);
            }
        }
    }
}
上一篇下一篇

猜你喜欢

热点阅读