resultMap生成

本文详细探讨了Java中resultMap的概念及其在数据库查询映射中的应用,揭示了如何通过resultMap优化数据检索效率,提升代码的可读性和维护性。通过对不同映射类型的解析,包括基本类型、复合类型以及关联映射,读者将全面了解resultMap的使用技巧。

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

public class Generator {
    private static final String FORMAT_ERROR = "数据格式错误";

    /**
     * resultMap拼接词缀
     */
    private static final String QUOTATION_MARK = "\"";
    private static final String RESULT_PREFIX = "<result property=";
    private static final String RESULT_COLUMN = " column=";
    private static final String RESULT_JDBCTYPE = " jdbcType=";
    private static final String RESULT_SUFFIX = "/>";

    /**
     * jdbc类型映射,java类型 - mybatis类型
     */
    private static Map<String, String> jdbcTypeMap;


    /**
     * 生成resultMap下单行result
     *
     * @param formatData 格式化数据,格式为 private type field;   只解析field,根据type转换
     * @return 格式化结果,格式为 <result property="java_field" column="database_field" jdbcType="JType"></result>
     * column为数据库字段,大写字母转换成_ , jdbcType按照MyBatis内置格式转换
     */
    public static String singleResultMapGenerator(String formatData) {
        if (formatData == null || formatData.length() == 0) return formatData;
        //按照空格格式化
        String[] splits = formatData.split(" ");
        if (splits.length < 2) return FORMAT_ERROR;
        //初始化map
        initJdbcTypeMap();
        StringBuilder result = new StringBuilder(RESULT_PREFIX);
        //只取最后两个数据,注意符号;
        splits[splits.length - 1] = splits[splits.length - 1].substring(0, splits[splits.length - 1].length() - 1);
        result.append(QUOTATION_MARK).append(splits[splits.length - 1]).append(QUOTATION_MARK)
                .append(RESULT_COLUMN).append(QUOTATION_MARK).append(humpConvertUnderline(splits[splits.length - 1])).append(QUOTATION_MARK);
        if (!jdbcTypeMap.containsKey(splits[splits.length - 2])) {
            return FORMAT_ERROR;
        }
        result.append(RESULT_JDBCTYPE).append(QUOTATION_MARK).append(jdbcTypeMap.get(splits[splits.length - 2])).append(QUOTATION_MARK)
                .append(RESULT_SUFFIX);

        return result.toString();
    }

    /**
     * 多行resultMap生成result
     *
     * @param formatData 格式化数据,有标准换行
     * @return 有标准换行的result标签
     */
    public static String multiResultMapGenerator(String formatData) {
        if (formatData == null || formatData.length() == 0) return formatData;
        String[] splits = formatData.split("\n");
        StringBuilder result = new StringBuilder();
        for (String s : splits) {
            result.append(singleResultMapGenerator(s)).append("\n");
        }
        return result.toString();
    }

    public static void main(String[] args) {
        System.out.println(multiResultMapGenerator("  private Integer id;\n" +
                "  private String applyId;"));
    }

    /**
     * 将驼峰命名转换为下划线命名
     */
    private static String humpConvertUnderline(String humpData) {
        if (humpData == null || humpData.length() <= 1) return humpData;
        StringBuilder result = new StringBuilder();
        //寻找变换位置
        for (int var1 = 0; var1 < humpData.length(); var1++) {
            if ('A' <= humpData.charAt(var1) && humpData.charAt(var1) <= 'Z') {
                result.append("_").append((char) (humpData.charAt(var1) + 32));
            } else {
                result.append(humpData.charAt(var1));
            }
        }
        return result.toString();
    }

    /**
     * 映射初始化,需要时使用
     * 初始化,保证原子性
     */
    private synchronized static void initJdbcTypeMap() {
        if (jdbcTypeMap == null) {
            jdbcTypeMap = new HashMap<>();
            jdbcTypeMap.put("String", "VARCHAR");
            jdbcTypeMap.put("BegDecimal", "DECIMAL");
            jdbcTypeMap.put("boolean", "BOOLEAN");
            jdbcTypeMap.put("Boolean", "BOOLEAN");
            jdbcTypeMap.put("byte", "TINYINT");
            jdbcTypeMap.put("Byte", "TINYINT");
            jdbcTypeMap.put("short", "SMALLINT");
            jdbcTypeMap.put("Short", "SMALLINT");
            jdbcTypeMap.put("int", "INTEGER");
            jdbcTypeMap.put("Integer", "INTEGER");
            jdbcTypeMap.put("long", "LONG");
            jdbcTypeMap.put("Long", "LONG");
            jdbcTypeMap.put("float", "REAL");
            jdbcTypeMap.put("Float", "REAL");
            jdbcTypeMap.put("double", "DOUBLE");
            jdbcTypeMap.put("Double", "DOUBLE");
            jdbcTypeMap.put("byte[]", "BINARY");
            jdbcTypeMap.put("Date", "DATE");
            jdbcTypeMap.put("Time", "TIME");
            jdbcTypeMap.put("Timestamp", "TIMESTAMP");
            jdbcTypeMap.put("java.sql.Timestamp", "TIMESTAMP");
            jdbcTypeMap.put("Clob", "CLOB");
            jdbcTypeMap.put("Blob", "BLOB");
            jdbcTypeMap.put("Array", "ARRAY");
            jdbcTypeMap.put("Struct", "STRUCT");
            jdbcTypeMap.put("Ref", "REF");
            jdbcTypeMap.put("URL", "DATALINK");
        }
    }

}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值