V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
whwq2012
V2EX  ›  Java

mybatis 中的 insert 不能使用 resultMap,如何来应对数据库表字段和实体类不相同的情况?

  •  
  •   whwq2012 · 2017-06-16 18:59:06 +08:00 · 5304 次点击
    这是一个创建于 2754 天前的主题,其中的信息可能已经有所发展或是发生改变。

    难道只能傻傻地一个个取别名吗?这太麻烦了吧。我用英文和中文,谷歌和百度都搜不出来,搜了一个小时,无奈才来提问的。希望有 java web 老司机来解惑

    11 条回复    2017-06-22 11:58:24 +08:00
    zhx1991
        1
    zhx1991  
       2017-06-16 21:02:13 +08:00
    当初为什么会不一致呢...
    whwq2012
        2
    whwq2012  
    OP
       2017-06-16 21:10:13 +08:00 via Android
    @zhx1991 数据库的字段的命名规范和属性的命名规范没统一
    slixurd
        3
    slixurd  
       2017-06-16 21:35:59 +08:00
    插入还能取别名....
    这是个啥....
    whwq2012
        4
    whwq2012  
    OP
       2017-06-16 21:51:15 +08:00 via Android
    @slixurd  解决办法一: 通过在查询的 sql 语句中定义字段名的别名,让字段名的别名和实体类的属性名一致,这样就可以表的字段名和实体类的属性名一一对应上了,这种方式是通过在 sql 语句中定义别名来解决字段名和属性名的映射关系的。

      解决办法二: 通过<resultMap>来映射字段名和实体类属性名的一一对应关系。这种方式是使用 MyBatis 提供的解决方式来解决字段名和属性名的映射关系的。
    http://www.cnblogs.com/xdp-gacl/p/4264425.html
    nonesuccess
        5
    nonesuccess  
       2017-06-16 22:25:07 +08:00
    @whwq2012 人家都说了不能用 resultMap
    slixurd
        6
    slixurd  
       2017-06-16 23:08:22 +08:00
    @whwq2012 那是用来查询的,SELECT 才有别名....
    和 INSERT 没有任何关系....
    看官方文档就行了
    http://www.mybatis.org/mybatis-3/sqlmap-xml.html
    手写 SQL 简单又方便....
    <insert id="insertAuthor">
    insert into Author (id,username,password,email,bio)
    values (#{id},#{username},#{password},#{email},#{bio})
    </insert>
    whwq2012
        7
    whwq2012  
    OP
       2017-06-17 09:30:10 +08:00
    @slixurd 但是我数据库里的字段名和实体类不一样,一运行就提示错误。。。
    Makki
        8
    Makki  
       2017-06-17 16:32:20 +08:00   ❤️ 1
    <insert id="save">
    insert into Person (DBFirstName, DBLastName, DBAge, DBGender)
    values (#{JAVAFirstName},#{JAVALastName},#{JAVAAge},#{JAVAGender})
    </insert>

    这样试试呢
    whwq2012
        9
    whwq2012  
    OP
       2017-06-17 22:16:04 +08:00
    @Makki 对对对,这样就行了
    nnxiaod
        10
    nnxiaod  
       2017-06-18 18:52:11 +08:00
    加个 parameterType 参数指定个实体类然后用实体类的字段,不行吗?
    indexry
        11
    indexry  
       2017-06-22 11:58:24 +08:00
    @nnxiaod 有道理 是这样的 <insert id="saveEntity" parameterType="com.ccys.fskx.entity.User" >

    id 的话你还可以这样<selectKey keyProperty="id" resultType="String" order="BEFORE">
    select replace(uuid(),'-','') from dual
    </selectKey>
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1014 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 21:50 · PVG 05:50 · LAX 13:50 · JFK 16:50
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.