在java中,在我们写一个java文件定义用户的属性时,有可能会出现用户定义的属性名和实际的列名不一致的问题,这时候,当我们操作一些数据的时候,就会出现一些错误,例如:当我们测试查询数据时,并不会报错,但是就是数据为空,而且数据库中也是有数据的,但就是查询出来为null;项目很大,数据很多时,我们显然不能通过再修改属性名来修改错误了,我们有另外三种方式取解决这个问题;
private Integer id; //模拟属性名与列名不一致的情况下; private String studentName; private Integer classid; private Integer version;
实际的列名:name属性名被改为studentName了;
当我们测试查询数据时,并不会报错,但是就是数据为空,而且数据库中也是有数据的,但就是查询出来null;
下面,有三种方式解决这个问题;
①重写属性名和列名不一致的属性的set方法;
public void setName(String name) { this.studentName = name; }
测试结果:
②在mapper配置文件中,给name取别名,以适配器student类中的studentName属性,这种方法比较常见,也比较实用;
测试结果:
③ 通过<resultMap>来映射字段名和实体类属性名的一一对应的关系;
<!--定义结果集映射,通过该映射来指定表的列与类的属性的映射关系--> <!--id:唯一表示; type:关联到实体类--> <resultMap id="studentResultMap" type="Student2"> <!--id:配置主键与实体类中属性的映射关系--> <id column="ID" property="id" jdbcType="DECIMAL"></id> <!--result:配置非主键列--> <result column="name" property="studentName"></result> <result column="classid" property="classid"></result> <result column="version" property="version"></result> </resultMap> <!--resultMap:指定返回的结果集映射的ID值--> <select id="selectByIdMappingWithResultMap" resultMap="studentResultMap"> select * from h_student where id=#{id} </select>