weixin_42261843 2008-09-06 10:07
浏览 141
已采纳

关于Hibernate。。一些小疑惑

本人比较热衷与ibatis以及纯生态sql:)但是碰到2个项目都是Hibernate,用着用着也就碰到麻烦了。



比如

Class User : userId, userName

Class Address : addId,userId, AddressName



一。

如果用HQL查询,需要 select userName,AddressName 这样来自2个不同类的字段,如何定义返回对象?



二。HQL一般返回整个对象,但是比如查询表Address,我只需要 userId,AddressName,不需要addId这个字段一起查出来,怎么处理呢?有时候返回一个带有Blob的对象是不明智的





谢谢各位了:)
问题补充:
到底有没有人认真看答案??



第一个问题是:一个select 查询的结果,包含2张不同表的字段, 如果定义这个返回的对象!!显然不是User或者Address。



第二个问题是:如果我只想知道Address中的 addId,AddressName,不需要返回userId,怎么做

  • 写回答

4条回答 默认 最新

  • icewubin 2008-09-08 13:31
    关注

    你的类定义的有问题,Class Address中不应该出现userId,应该是User user类,配置ManyToOne,然后hql如下。

    第一个问题:
    select u.userName, a.AddressName from Address a join User u
    或者隐式内连接
    select a.user.userName, a.AddressName from Address a

    返回类型是List,每个Object在这个例子中都可以强转成String类型。

    第二个问题:
    select a.addId, a.AddressName from Address a join User u
    where u.userName='admin'
    如果事先知道userId也可如下:
    select a.addId, a.AddressName from Address a
    where a.user.userId='5566'//假设是字符串

    返回类型是List,每个Object在这个例子中都可以强转成String类型。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

悬赏问题

  • ¥15 identifier of an instance of 类 was altered from xx to xx错误
  • ¥100 反编译微信小游戏求指导
  • ¥15 docker模式webrtc-streamer 无法播放公网rtsp
  • ¥15 学不会递归,理解不了汉诺塔参数变化
  • ¥30 软件自定义无线电该怎样使用
  • ¥15 R语言mediation包做中介分析,直接效应和间接效应都很小,为什么?
  • ¥15 Jenkins+k8s部署slave节点offline
  • ¥15 如何实现从tello无人机上获取实时传输的视频流,然后将获取的视频通过yolov5进行检测
  • ¥15 WPF使用Canvas绘制矢量图问题
  • ¥15 用三极管设计一个单管共射放大电路