zoukankan      html  css  js  c++  java
  • mybatis——解决属性名和数据库字段名不一致问题

    首先说一下,我的数据库名字叫mybatis,里边有一张user表,表中有三个字段,id、name、pwd;然后实体类中对应三个属性id、name、password(id和name跟数据库字段名一致,但是第三个属性password和数据库的字段pwd不同)

     解决方案

    方式一:起别名

      在映射文件中给sql语句里的字段取别名

    <select id="getUserById" parameterType="int" resultType="user">
            select id,name,pwd AS password from mybatis.user WHERE id = #{id}
    </select>

    *注意:

      若数据库字段名和实体类的属性名相同,则可以不用取别名

    方式二:使用resultMap(结果集映射)

    <resultMap id="UserMap" type="user">
      <result column="pwd" property="password"/>
    </resultMap>
    <select id="getUserById" parameterType="int" resultMap="UserMap">
        select * from mybatis.user WHERE id = #{id}
    </select>

    注意:

      若数据库字段名和实体类的属性名相同,则resultMap中可以不用写它们的result标签。当然写上也是没关系的,例如:

    <resultMap id="UserMap" type="user">
      <result column="id" property="id">
      <result column="name" property="name">   <result column="pwd" property="password"/> </resultMap> <select id="getUserById" parameterType="int" resultMap="UserMap"> select * from mybatis.user WHERE id = #{id} </select>
  • 相关阅读:
    程序员开发工作之算法和架构
    iOS开发学习概述及知识整理
    git基本技巧及进阶
    使用命令行工具运行Xcode 7 UI Tests
    技巧集锦2
    Xcode开发小问题集锦
    Xcode 7如何 免费 真机调试iOS应用
    常用shell script 珍藏
    多线程学习7--CountDownLatch
    学习多线程6---栅栏
  • 原文地址:https://www.cnblogs.com/bear7/p/12499577.html
Copyright © 2011-2022 走看看