Loading

Mybatis使用ResultMap

解决字段名和属性名不一致的问题

  - 新建数据库表的字段-这里就不贴上了
  在下面链接有

https://www.cnblogs.com/rzkwz/p/12853899.html

设置实体类和数据库字段名不一致

测试查询

新建Mapper接口

  public interface UserMapper {
      //查询全部用户
      List<User> getUserAll();
  }

新建Mapper.xml

  <?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.rzk.mapper.UserMapper">
      <!--查询全部用户-->
      <select id="getUserAll" resultType="User">
          select * from user
      </select>
  </mapper>

测试

      @Test
      public void getUserAll(){
          SqlSession sqlSession = MybatisUtils.getSqlSession();
          UserMapper mapper = sqlSession.getMapper(UserMapper.class);
          List<User> all = mapper.getUserAll();
          for (User user : all) {
              System.out.println(user);
          }
      }

username和password为空

解决方法

起别名

       <!--查询全部用户-->
      <select id="getUserAll" resultType="User">
          select id,name AS username,pwd as password  from user
      </select>

使用resultMapper

  • 结果集映射

      <resultMap id="UserMap" type="user">
      <!--property: 实体类中的属性    column:数据库中的字段-->
      <!--数据库中的一个列 映射成数据库中的字段-->
      <result property="username" column="name"/>
      <result property="password" column="pwd"/>
      </resultMap>
      <!--查询全部用户-->
      <select id="getUserAll" resultMap="UserMap">
           select * from user
      </select>
    

Result总结

resultMap元素是MyBatis中最重要、最强大的元素。它允许您去掉JDBC从resultset检索数据所需的90%的代码,并且在某些情况下允许您做JDBC甚至不支持的事情。实际上,为复杂语句的join映射之类的东西编写等价的代码可能需要跨越数千行代码。ResultMaps的设计是这样的:简单的语句根本不需要显式的结果映射,而更复杂的语句只需要描述这些关系即可。

posted @ 2020-05-09 19:15  Rzk  阅读(547)  评论(0编辑  收藏  举报