addScalar的用法与作用
作用:
1.提高性能
2.指定要返回哪几个字段,为指定的不返回(主要用于select *查询全部)
3.也可指定返回字段的具体类型
详细讲解如下:
最基本的SQL查询就是获得一个标量的列表:
1 | session.createSQLQuery( "select * from person_inf" ).list(); <br>session.createSQLQuery( "select id,name,age from person_inf" ).list(); |
它们都将返回一个Object数组组成的List,数组每个元素都是person_inf表的一个字段值。 Hibernate会使用ResultSetMetadata来判定返回的标量值的实际顺序和类型。
但是在JDBC中 过多的使用ResultSetMetadata会降低程序的性能。所以为了过多的避免使用ResultSetMetadata或者为了指定更加明确的返回值类型,我们可以使用addScalar()方法:
1 2 | session.createSQLQuery( "select * from person_inf" ) <br>.addScalar( "name" ,StandardBasicTypes.STRING) .addScalar( "age" ,StandardBasicTypes. INT )<br>.list(); |
这个查询指定了:
1、SQL查询字符串。
2、要返回的字段和类型。
它仍然会返回Object数组,但是此时不再使用ResultSetMetdata,而是明确的将name和age按照String和int类型从resultset中取出。同时,也指明了就算query是使用*来查询的,可能获得超过列出的这三个字段,也 仅仅会返回这三个字段。
如果仅仅只需要选出某个字段的值,而不需要明确指定该字段的数据类型,则可以使用addScalar(String columnAlias)。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 | public void scalarQuery(){ Session session = HibernateUtil.getSession(); Transaction tx = session.beginTransaction(); String sql = "select * from person_inf" ; List list = session.createSQLQuery(sql). addScalar( "person_id" ,StandardBasicTypes. INTEGER ). addScalar( "name" , StandardBasicTypes.STRING). addScalar( "age" ,StandardBasicTypes. INTEGER ).list(); for (Iterator iterator = list.iterator();iterator.hasNext();){ //每个集合元素都是一个数组,数组元素师person_id,person_name,person_age三列值 Object[] objects = (Object[]) iterator. next (); System. out .println( "id=" +objects[0]); System. out .println( "name=" +objects[1]); System. out .println( "age=" +objects[2]); System. out .println( "----------------------------" ); } tx. commit (); session. close (); } |
从上面可以看出。标量查询中addScalar()方法有两个作用:
1、指定查询结果包含哪些数据列---没有被addScalar选出的列将不会包含在查询结果中。
2、指定查询结果中数据列的数据类型
分类:
三大框架相关
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix