Hibernate中使用未映射为主键的“id”字段进行查询的场景分析

今天遇到一个hibernate的问题,有一个实体的主键字段叫userId,数据库里的字段名称是user_id。
然后在某个查询语句里有这样一段代码:

Criterion criterion = Restrictions.eq("id",userId);
User user=userDao.findUnique(criterion);

当时看到这段代码的感觉是应该会报错吧,因为这个实体并没有id这个字段,然而事实是不仅可以运行,结果还是正确的。
搜索了下网络,发现有网友遇到类似的问题,但是没有找到问题的原因。原帖如下:

Hibernate处理非主键字段名称为id的问题

跟踪了一下hibernate的源代码,发现在hibernate启动生成映射关系的时候,会先初始化普通字段的映射关系,再初始化主键字段的映射关系,如下图所示:

Hibernate初始化字段映射关系

而这种主键字段的初始化,也就是initIdentifierPropertyPaths(mapping)这个方法,不仅会生成userId->user_id的映射关系,还会生成一条id->user_id到映射关系。

至此,问题的原因已经明朗了,我遇到的问题是因为hibernate自动生成了id的映射,所以可以访问到id属性。而网友的问题则是,hibernate第二步自动生成的id映射关系覆盖了第一步普通属性里id的映射关系。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值