mybatis 多表联合查询,重复字段映射问题

ZZZ5512536 2014-07-02 04:28:03
数据库公司表A, 区域表B表都有id字段,且A表外键area_id关联B表id, java类也都是命名为id,
resultMap定义如下:

// 公司
<resultMap id="BaseResultMap" type="Company" >
<id column="id" property="id" jdbcType="BIGINT" />
<result column="address" property="address" jdbcType="VARCHAR" />
<association property="area" column="id" javaType="Area" resultMap="AreaMapper.BaseResultMap"/>
</resultMap>

// 区域
<resultMap id="BaseResultMap" type="Area">
<id column="id" property="id" jdbcType="BIGINT" />
<result column="area_name" property="name" jdbcType="VARCHAR" />
</resultMap>


如果执行关联查询SQL,获得的company对象打印结果如下
Company [id=18, address=测试, area=Area [id=18, name=北京]] // 实际area的id为1
公司里的区域id会一直与公司id保持一样. 当然如果将数据库的区域id使用areaid区分开来,结果就是正确的.

想问的就是如果数据库都用id字段,且java类也用id,怎样才能得到正确的数据呢

...全文
3693 13 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
13 条回复
切换为时间正序
请发表友善的回复…
发表回复
DuskForRain 2017-03-23
  • 打赏
  • 举报
回复
加一个别名就可以了
我爱娃哈哈 2017-03-14
  • 打赏
  • 举报
回复
引用 3 楼 uwolf1233 的回复:
还是自己封装框架比较好,感觉用别人的框架想实现一些东西还要去看去学,自己写的,自己去改就行了
这是我见过最屌的人
浮云若水 2017-03-14
  • 打赏
  • 举报
回复
实体类是实体类 DTO 是DTO DTO中的字段可以自定义 在sql中 用 as 来对相同字段 取不同别名 这样就会根据as 别名来注入对应的字段
浮云若水 2017-03-14
  • 打赏
  • 举报
回复
引用 3 楼 uwolf1233 的回复:
还是自己封装框架比较好,感觉用别人的框架想实现一些东西还要去看去学,自己写的,自己去改就行了
这个好 值得学习
捉蝉 2017-03-14
  • 打赏
  • 举报
回复
查询的时候 使用AS 关键字 另外 column的值匹配上你设置的别名 实体类也需要改哦
ws199199 2017-03-11
  • 打赏
  • 举报
回复
好问题,学到了
Swen程序员 2016-09-08
  • 打赏
  • 举报
回复
这个可以用别名的方式,然后在resultMap里面再改一下column就可以了
wmaosheng 2016-09-08
  • 打赏
  • 举报
回复
我也遇到这个问题了,想问一下你是怎么解决的啊
Intboy 2016-06-22
  • 打赏
  • 举报
回复
引用 3 楼 uwolf1233 的回复:
还是自己封装框架比较好,感觉用别人的框架想实现一些东西还要去看去学,自己写的,自己去改就行了
好牛逼的样子
赵雍 2016-06-22
  • 打赏
  • 举报
回复
大神,你写过框架?
uwolf1233 2015-02-14
  • 打赏
  • 举报
回复
还是自己封装框架比较好,感觉用别人的框架想实现一些东西还要去看去学,自己写的,自己去改就行了
字节侠 2015-02-05
  • 打赏
  • 举报
回复
// 公司 <resultMap id="BaseResultMap" type="Company" > <id column="id" property="id" jdbcType="BIGINT" /> <result column="address" property="address" jdbcType="VARCHAR" /> <association property="area" column="id" javaType="Area" resultMap="AreaMapper.BaseResultMap"/> </resultMap> // 区域 <resultMap id="BaseResultMap" type="Area"> <id column="area_id" property="id" jdbcType="BIGINT" /> <result column="area_name" property="name" jdbcType="VARCHAR" /> </resultMap> <select id="findAll" resultMap="BaseResultMap"> SELECT *, id AS area_id FROM area </select>
ZZZ5512536 2014-07-02
  • 打赏
  • 举报
回复
就没人回答么

81,122

社区成员

发帖
与我相关
我的任务
社区描述
Java Web 开发
社区管理员
  • Web 开发社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧