java 字符串组装成DTO对象

本文介绍了如何通过字符串操作将数据字段映射到对象的各个属性上,包括不同类型数据类型的处理和异常检查。展示了使用split()、getDeclaredFields()和invoke()方法动态设置DTO对象的详细过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、字符串与对象字段应该相对应

Object dto = new User();

public String assembleCoreDTO(String line, Object dto) throws BaseApplicationException {
        String errInfo = "";
        try {
            // 栏位数组
            String[] fieldVals = line.split("\\|@\\|");
            // 装载DTO
            Field[] fields = dto.getClass().getDeclaredFields();
            for (int i = 0; i < fields.length; i++) {
                String fieldVal = fieldVals[i].trim();
                Field field = fields[i];
                try {
                    if (!StringUtils.isEmpty(fieldVal)) {
                        String methodName = "set" + field.getName().substring(0, 1).toUpperCase() + field.getName().substring(1);
                        if (BigDecimal.class.getName().equals(field.getType().getTypeName())) {
                            Method method = dto.getClass().getMethod(methodName, BigDecimal.class);
                            method.invoke(dto, new BigDecimal(fieldVal));
                        } else if (Integer.class.getName().equals(field.getType().getTypeName())) {
                            Method method = dto.getClass().getMethod(methodName, Integer.class);
                            method.invoke(dto, Integer.valueOf(fieldVal));
                        } else if (Timestamp.class.getName().equals(field.getType().getTypeName())) {
                            Method method = dto.getClass().getMethod(methodName, Timestamp.class);
                            method.invoke(dto, new Timestamp(DateUtil.stringToDate(fieldVal).getTime()));
                        } else if (Date.class.getName().equals(field.getType().getTypeName())) {
                            Method method = dto.getClass().getMethod(methodName, Date.class);
                            method.invoke(dto, DateUtil.stringToDate(fieldVal, DateUtil.DATE_PATTERN_YYYY_MM_DD));
                        } else {
                            Method method = dto.getClass().getMethod(methodName, String.class);
                            method.invoke(dto, fieldVal);
                        }
                    }
                } catch (Exception e) {
                    DlValidate dlValidate = field.getDeclaredAnnotation(DlValidate.class);
                    if (dlValidate.desc() != null) {
                        errInfo += dlValidate.desc() + "解析异常;";
                    } else {
                        errInfo += "第" + (i + 1) + "个栏位解析异常;";
                    }
                }
            }
        } catch (Exception e) {
            errInfo += "数据格式错误;";
        }
        return errInfo;
    }

//返回后dto就有值了
### 将 DTO 参数传递给 MyBatis Mapper 在 Java 应用程序中,DTO(Data Transfer Object)通常用于封装数据以便于不同层次之间的传输。当使用 MyBatis 作为持久化框架时,可以通过将 DTO 对象直接传递给 Mapper 接口的方法来进行数据库操作。 #### 定义 DTO 类 首先创建一个表示实体的数据传输对象 (DTO),该对象应包含必要的字段以及相应的 getter 和 setter 方法: ```java public class PersonDTO { private Integer id; private String name; // Getters and Setters omitted for brevity. } ``` #### 编写 Mapper XML 文件中的 SQL 映射语句 接着,在对应的 Mapper XML 文件里编写 SQL 查询语句,并指定参数类型为上述定义好的 `PersonDTO`: ```xml <select id="selectPersonById" parameterType="com.example.PersonDTO" resultType="com.example.Person"> SELECT * FROM PERSON WHERE ID = #{id} AND NAME LIKE CONCAT('%',#{name},'%') </select> ``` 这里需要注意的是,`${}` 是字符串替换的方式,而 `#{}` 则会被解析预编译的 SQL 语句的一部分并安全地设置参数值[^2]。 #### 实现 Mapper 接口方法签名 最后一步是在 Mapper 接口中声明相应的方法,接受 `PersonDTO` 类型的参数: ```java package com.example.mapper; import org.apache.ibatis.annotations.Param; import java.util.List; public interface PersonMapper { List<Person> selectPersonById(@Param("dto") PersonDTO dto); } ``` 通过这种方式,可以方便地把业务逻辑层组装好后的 DTO 数据结构传入到 MyBatis 的 Mapper 层执行具体的 CRUD 操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值