自定义获取字段属性

请教!!有一个需求
{
“total”:4,
“fieldNum”:3,
“data”: [
{ “ID”:“1” , “NAME”:“Gates”, “AGE”:18},
{ “ID”:“2” , "NAME:“Bill”, " AGE ":17},
{ “ID”:“3” , “NAME”:“Sam”, " AGE ":17},
{ “ID”:“4” , “NAME”:“Bob”, “AGE”:18}
]
}
这个是用户传过来的数据格式,要求在自动建表的时候根据数据类型自定义字段类型
比如 AGE=18 要求根据18这个值设定AGE的类型为int

    public void createTable(Connection connection, String tableName, String[] columns) {
    if (tableName == null || "".equals(tableName) || columns.length == 0) {
        return;
    }
    String sql = "CREATE TABLE " + tableName;
    StringBuilder columnSql = new StringBuilder("(gp_uuid varchar(128) PRIMARY KEY, gp_timestamp timestamp(8),");
    for (String column : columns) {
        columnSql.append(column).append(" varchar(255),");
    }
    columnSql.deleteCharAt(columnSql.length() - 1);
    columnSql.append(")");
    sql += columnSql.toString();
    try {
        Statement st = connection.createStatement();
        boolean success = st.execute(sql);
    } catch (SQLException e) {
        e.printStackTrace();
    }
}          `

这个是建表的方法 有什么办法吗 大佬们????

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用Spring的BeanUtils.copyProperties方法进行自定义映射字段属性拷贝,可以通过BeanWrapper来实现。以下是一个示例: 假设有两个bean:User和UserDTO,它们的属性不完全一致,需要进行自定义映射字段属性拷贝。User类中有属性username和age,UserDTO类中有属性name和ageGroup,需要将username映射到name,将age映射到ageGroup。 ```java public class User { private String username; private Integer age; // 省略getter/setter方法 } public class UserDTO { private String name; private String ageGroup; // 省略getter/setter方法 } ``` 可以使用如下代码进行自定义映射字段属性拷贝: ```java User user = new User(); user.setUsername("张三"); user.setAge(25); UserDTO userDTO = new UserDTO(); BeanWrapper userWrapper = new BeanWrapperImpl(user); BeanWrapper userDTOWrapper = new BeanWrapperImpl(userDTO); PropertyDescriptor[] pds = userWrapper.getPropertyDescriptors(); for (PropertyDescriptor pd : pds) { if (pd.getWriteMethod() != null && pd.getReadMethod() != null) { if ("username".equals(pd.getName())) { userDTOWrapper.setPropertyValue("name", userWrapper.getPropertyValue(pd.getName())); } else if ("age".equals(pd.getName())) { Integer age = (Integer) userWrapper.getPropertyValue(pd.getName()); if (age < 18) { userDTOWrapper.setPropertyValue("ageGroup", "未成年"); } else if (age > 60) { userDTOWrapper.setPropertyValue("ageGroup", "老年人"); } else { userDTOWrapper.setPropertyValue("ageGroup", "成年人"); } } } } System.out.println(userDTO.getName()); // 输出:张三 System.out.println(userDTO.getAgeGroup()); // 输出:成年人 ``` 在上述代码中,通过BeanWrapper来获取源对象和目标对象的属性描述符PropertyDescriptor,遍历源对象的属性描述符PropertyDescriptor,在目标对象中查找对应的属性描述符PropertyDescriptor。如果找到对应的目标属性,则将源属性的值复制到目标属性中;如果未找到对应的目标属性,则根据自定义映射规则,创建一个新的目标属性,并将源属性的值复制到新的目标属性中。最终,将拷贝后的UserDTO对象输出。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值