mybatis 中的 insert 不能使用 resultMap,如何来应对数据库表字段和实体类不相同的情况? - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
syahd
V2EX    Java

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

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

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

    11 条回复    2017-06-22 11:58:24 +08:00
    zhx1991
        1
    zhx1991  
       2017-06-16 21:02:13 +08:00
    当初为什么会不一致呢...
    syahd
        2
    syahd  
    OP
       2017-06-16 21:10:13 +08:00 via Android
    @zhx1991 数据库的字段的命名规范和属性的命名规范没统一
    slixurd
        3
    slixurd  
       2017-06-16 21:35:59 +08:00
    插入还能取别名....
    这是个啥....
    syahd
        4
    syahd  
    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>
    syahd
        7
    syahd  
    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>

    这样试试呢
    syahd
        9
    syahd  
    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     Solana     5439 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 25ms UTC 07:40 PVG 15:40 LAX 00:40 JFK 03:40
    Do have faith in what you're doing.
    ubao snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86