项目中会经常用到实体的字体与数据库对应字段的一种转换,可以利用fastjson进行字段映射,达到相互转化的效果,或者是同步数据的时候也需要做相应的转换,下面介绍下在项目中真实应用的场景:
需求是:同步数据甲方要求同步的数据为:
{
"yy_id": "0",
"yy_create_user_id": "bjtoon_312672", "yy_create_user_name": "0", "yy_create_time": "2017-01-06 15:41:26"}
而我方所对应字段是一个实体对象
yyId,
yyCreateUserId,
yyCreateUserName,
yyCreateTime
那么怎么能够实现这种转换呢
利用fastjson的注解来做,可以定义一个Vo对象来实现轻松转换
第一种:注解
public class TestVo implements Serializable { private static final long serialVersionUID = 1L; @JSONField(name = "yy_id") private String yyId; @JSONField(name = "yy_create_user_id") private String yyCreateUserId; @JSONField(name = "yy_create_user_name") private String yyCreateUserName; @JSONField(name = "yy_create_time") private Date yyCreateTime; //省略set get方法}
可以使用json序列化进行转化
String json = "{"yy_id": "0","yy_create_user_id": "bjtoon_312672","yy_create_user_name": "0","yy_create_time": "2017-01-01 15:41:26"}";TestVo testVo = JSON.parseObject(json,TestVo .class);
通过这种转换就能得到实体对象。
第二种:
String json = JSON.toJSONString(TestVo);
序列化后的json如上所示:{"yy_id": "0","yy_create_user_id": "bjtoon_312672","yy_create_user_name": "0","yy_create_time": "2017-01-01 15:41:26"}
这样就能达到相互转换进行数据入库。