博客
关于我
在hql中写sql 获值
阅读量:99 次
发布时间:2019-02-25

本文共 672 字,大约阅读时间需要 2 分钟。

序言:

一贯使用hibernate,就直接使用他的方法或者构造函数就行了,但是有些时候,使用的时候要注意一些方面:

如业务需要你对sql语句进行联查,排序和聚会处理。

问题:

使用一套固定的整合框架进行开发,框架的实现中,加入了分页的实现,因为有了分页的实现,所以在处理如聚会函数,联查表的时候,就会出现弊端。

使用hql 去执行sql ,得到的对象就是Object 的,调试会发现,呈现的样子是:["a","b","c","d"] . 那么如何去取得它们呐 ?

尝试方案:

1.在得到数据的时候进行强制转换;经过尝试,此法行不通,无法进行强转。即无法将Oject——> String| List | Array ,

2.取值来封装;经过尝试,依然失败,即无法将Oject 类型的对象取值封装成: String| List | Array ,

解决方案:

直接将结果返回给页面,在页面处理。

写sql 语句,在经过hibernate的hql处理之后,他会将你写的sql的字段用类似["a","b","c","d"] 的对象包装在Ojbect中,所以在页面获取的时候,可以使用

<s:property value="#list[0]"/> 来获取:list 表示list的对象实例,[0] 表示的是下标为0的字段的值。

如此一来,就可以将手动写的sql在hql执行完成之后,将对应的值显示在页面上了。

注意点:

一般这样的情况很少出现,因为hibernate已经有很好的封装,不需要这样来操作。如需要这样操作,即可以采用

如上述所使用方法来处理。

转载地址:http://oou.baihongyu.com/

你可能感兴趣的文章
MySQL中的GROUP_CONCAT()函数详解与实战应用
查看>>
MySQL中的IO问题分析与优化
查看>>
MySQL中的ON DUPLICATE KEY UPDATE详解与应用
查看>>
mysql中的rbs,SharePoint RBS:即使启用了RBS,内容数据库也在不断增长
查看>>
mysql中的undo log、redo log 、binlog大致概要
查看>>
Mysql中的using
查看>>
MySQL中的关键字深入比较:UNION vs UNION ALL
查看>>
mysql中的四大运算符种类汇总20多项,用了三天三夜来整理的,还不赶快收藏
查看>>
mysql中的字段如何选择合适的数据类型呢?
查看>>
MySQL中的字符集陷阱:为何避免使用UTF-8
查看>>
mysql中的数据导入与导出
查看>>
MySQL中的时间函数
查看>>
mysql中的约束
查看>>
MySQL中的表是什么?
查看>>
mysql中穿件函数时候delimiter的用法
查看>>
Mysql中索引的分类、增删改查与存储引擎对应关系
查看>>
Mysql中索引的最左前缀原则图文剖析(全)
查看>>
MySql中给视图添加注释怎么添加_默认不支持_可以这样取巧---MySql工作笔记002
查看>>
Mysql中获取所有表名以及表名带时间字符串使用BetweenAnd筛选区间范围
查看>>
Mysql中视图的使用以及常见运算符的使用示例和优先级
查看>>