hibernate 返回不同表中的数据

  我们做的内部项目,这周一检查v0版了,感觉有一些逻辑是我没想到的,看来自己在这方便还是要多努力;对于hibernate的一些应用,还是不太会用,哎,不过总算是自己前后台都完成了大部分。来说说hibernate返回两张不同表字段数据。

  需求是这样的:想要返回task的一些信息,和task的状态(有一张专门的TaskStatus表)。

  这涉及到task、taskStatus两张表,有两种办法,一个是写一个包含所有需要返回字段的pojo;一个是在SQLQuery后面加上addEntity().addEntity()。前一种方式可以选择性返回字段,而后一种方式在select 后面只能返回这两张表的所有字段,即 TableName.* 。

  我把两种方式分别列出来:

  方式一:写一个TaskAdnStatusPojo.java

                dao层的query如下:

                 

Query query = getSession().createSQLQuery("select tstatus.sTaskId,task.tAssignee,task.tTitle,task.tCreateId," +

                "task.tDescription,task.tDeadLine,task.tSource,tuser.uName," +

                "task.tFinisher,tstatus.sStatus " +

                "from Ttask task, Ttaskstatus tstatus,tuser where task.tId=tstatus.sTaskId and task.tAssignee=tuser.uId                         and tstatus.sIsNew='Y'")

                .setResultTransformer(Transformers.aliasToBean(TaskAndStatusPojo.class));

或者把红色那段换成:

                .setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP);

        两者的区别:前一种在返回值含有日期的时候,会调用model中的对应get/set方法来转换日期格式,而后种不会调用model中的方法。


    方式二:以addEntity的方式

            

Query query = getSession().createSQLQuery("select task.*, tstatus.* " +

                "from Ttask task, Ttaskstatus tstatus where task.tId=tstatus.sTaskId and tstatus.sIsNew='Y'")

                .addEntity(Ttask.class).addEntity(Ttaskstatus.class);


        这两种方式都可以实现功能,看自己的喜好吧。需要特别注意的是:在使用pojo类的时候,需要给它一个默认的构造方法,不然会报错。



        


转载于:https://my.oschina.net/xiaoyuHe/blog/473686

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值