mybitis中对象字段与表中字段名称不匹配(复制)
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mybitis中对象字段与表中字段名称不匹配(复制)相关的知识,希望对你有一定的参考价值。
开发中,实体类中的属性名和对应的表中的字段名不一定都是完全相同的,这样可能会导致用实体类接收返回的结果时导致查询到的结果无法映射到实体类的属性中,那么该如何解决这种字段名和实体类属性名不相同的冲突呢?
方法一:通过在查询的SQL语句中定义字段名的别名的方式,让字段名的别名和实体类中的属性名一致,这样就可以实现实体类属性和表字段一一对应。(通过在SQL语句中定义别名的方法实现)
- <select id="queryCertificationInfoByCerNumber" parameterType="string" resultMap="certificationResultMap">
- SELECT cer_number cerNumber FROM, cer_time cerTime, cer_type cerType t_diamond_allinfo_gia WHERE cer_number = #{cerNumber}
- </select>
方法二:通过<resultMap>来映射字段名和实体类属性名的一一对应关系。(使用Mybatis提供的解决方法)
- <?xml version="1.0" encoding="UTF-8"?>
- <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
- "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
- <mapper namespace="com.jqscm.mapper.SearchMapper">
- <select id="queryCertificationInfoByCerNumber" parameterType="string" resultMap="certificationResultMap">
- SELECT * FROM t_diamond_allinfo_gia WHERE cer_number = #{cerNumber}
- </select>
- <!-- 通过resultMap映射实体类和表字段的关系 -->
- <resultMap type="CertificationInfo" id="certificationResultMap">
- <!-- 用id属性来映射主键字段 -->
- <id property="cerNumber" column="cer_number"/>
- <!-- 用result属性来映射非主键字段 -->
- <result property="cerTime" column="cer_time"/>
- <result property="cerType" column="cer_type"/>
- <result property="shape" column="shape"/>
- <result property="size" column="size"/>
- </resultMap>
- </mapper>
以上是关于mybitis中对象字段与表中字段名称不匹配(复制)的主要内容,如果未能解决你的问题,请参考以下文章
java中一个对象的属性为String 在mysql中对应text列 表有该列数据,可是读取该列的时候为null,求解决方法
MySQL LEFT JOIN json 字段与表中的另一个 id