首先在mapper里面,有这样两个select
第一个select 选出了一个值叫attribute,第二个select也选出了一个值叫attribute,第一个attribute为1,第二个为2
现在我需要把attribute这个值映射到一个Map字段上面去
下面是resultMap,这两个select都公用一个resultMap
在attribute的result中,定义了一个typeHandler
下面是typeHandler
在我的测试dao中,调用了两个select的方法,然后把他们的map全部输出却发现,所有的键值对都是2,
问题:为什么会出现这种情况,应该如何解决?我总不能为每一个select都写一个resultMap吧?尽管他们的映射都是一样的,但是有没有其他的解决方法?
希望大家不吝赐教!
抽象出来一个结果集resultMap,然后返回类型传id就好,可以复用
你的两个查询的字段 as attribute 不一样!!!
。。。 看花了,看成了s
感觉问题应该出在handler,你把type 也换成 colum的值试试,还是一样的么
handler的问题,key永远都是“type”
又因为同一个mapper在mybatis中就是同一个对象,而typehandler又是mapper对象的一个属性,所以相当于这种写法typehandler中的map对象始终同一个map。
而key始终是“type”value总是被后边的覆盖,最终取值时只能是对后一个。
你这种情况直接debug啊