hibernate下hql与sql查询结果的问题

hibernate可使用对象查询、hql语句查询、sql原生语句查询等方式。

遇到问题:dao层查询的结果装入list,返回biz,action,jsp后用EL表达式遍历显示,但出了异常,异常内容为格式转换。查询的内容从前到后有id,name等,异常就是id为string不能转为integer,注释掉id后又报name不能转啥啥啥。没有具体抛出位置。

查询后发现dao层使用的是sql查询方式,原生语句一般要写select部分指出查询字段,并且查询结果不会自动封装进实体类,这就是问题所在。

解决方法:改用hql语句,这样就可以用el表达式打点取值了。想用sql可以手动在业务层封装,不过麻烦。对象查询也可以,但是我想自定义查询条件所以用的语句。

总结:

hibernate的内置方法很方便,增删改都是一行两个点的事,注意传递来的要是对象,并且必须有序列值,改的时候对象中所有属性都会改,所以业务层调用修改时最好先查出来整个对象,修改其中要改的属性后再update

hql语句查询的结果可以自动封装进实体类,但自己写了select后会破坏封装。如何保持封装网上都有,可以select new 对象等等。

原生sql在语句中封装不好,查询的结果会是Object[]格式的数组,需要用List<Object[]>来接受,之后直接getIndex,object[n]取值,或者手动这样封装进实体类使用,比较麻烦但是灵活。这已经和JDBC差不多了吧。


于是,这次遇到的问题就是查询结果是object数组,但当做封装好的实体类世界在el表达式中使用,在我不知道的情况下object强转类型时出错。也许这就是mybatis的优势?

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值