MyBatis(三)——解决字段名与实体类属性名不相同的问题

2017-07-02  本文已影响0人  HCherisher

我们之前的Users表,有三个字段:


Users.png

我的实体类有三个名字相同的属性:

User
 但是在平时的开发中,我们表中的字段名和表对应实体类的属性名称不一定都是完全相同的,当名字不相同的时候就会引发一些问题。(比如我们的表中字段名都有一个前缀三个字段分别为user_id,user_name,user_age)

下面我们以userMapper.xml中的getUser为例:

 <!-- 根据id查询得到一个User对象,使用这个查询是查询不到我们想要的结果的,这主要是因为实体类的属性名和数据库的字段名对应不上的原因,因此无法查询出对应的记录-->
<select id="getUser" parameterType="int" 
        resultType="pers.cherish.entity.User">
        select * from users where id=#{id}
</select>

这样我们用之前的测试类TestCRUDByXmlMapper测试,我们会发现返回了一个null,当实体类中的属性名和表中的字段名不一致时,使用MyBatis进行查询操作时无法查询出相应的结果的问题以及针对问题采用的两种办法:

解决办法一:

通过在查询的sql语句中定义字段名的别名,让字段名的别名和实体类的属性名一致,这样就可以表的字段名和实体类的属性名一一对应上了,这种方式是通过在sql语句中定义别名来解决字段名和属性名的映射关系的。
修改userMapper.xml对应的配置信息

<!-- 
根据id查询得到一个user对象,使用这个查询是可以正常查询到我们想要的结果的,这是因为我们将查询的字段名都起一个和实体类属性名相同的别名,这样实体类的属性名和查询结果中的字段名就可以一一对应上-->
<select id="getUser2" parameterType="int" 
    resultType="pers.cherish.entity.User">
    select user_id id, user_name name, user_age age from users where user_id=#{id}
</select>
解决办法二:

通过<resultMap>来映射字段名和实体类属性名的一一对应关系。这种方式是使用MyBatis提供的解决方式来解决字段名和属性名的映射关系的。

 <!-- 
   根据id查询得到一个User对象,使用这个查询是可以正常查询到我们想要的结果的,这是因为我们通过<resultMap>映射实体类属性名和表的字段名一一对应关系 
 -->
<select id="getUser3" parameterType="int" resultMap="userResultMap">
    select * from users where user_id=#{id}
</select>
 <!--通过<resultMap>映射实体类属性名和表的字段名对应关系 -->
<resultMap type="pers.cherish.entity.User" id="userResultMap">
    <!-- 用id属性来映射主键字段 -->
    <id property="id" column="user_id"/>
    <!-- 用result属性来映射非主键字段 -->
    <result property="name" column="user_name"/>
    <result property="age" column="user_age/> 
</resultMap>

以上两种方式都可以解决,实体类属性和表列名不一致的问题

上一篇 下一篇

猜你喜欢

热点阅读