开发app的平台,seo外链工具有用吗,沅江网站设计公司,长沙网站seo技巧HQL尽管容易使用#xff0c;但是在一些复杂的数据操作上功能有限。特别是在实现复杂的报表统计与计算#xff0c;以及多表连接查询上往往无能为力#xff0c;这时可以使用SQL#xff08;Native SQL#xff09;实现HQL无法完成的任务。 1、使用SQL查询
使用SQL查询可以通过… HQL尽管容易使用但是在一些复杂的数据操作上功能有限。特别是在实现复杂的报表统计与计算以及多表连接查询上往往无能为力这时可以使用SQLNative SQL实现HQL无法完成的任务。 1、使用SQL查询
使用SQL查询可以通过两种方式来实现
1、利用Hibernate提供的SQLQuery对象执行。即可以通过Session对象的createSQLQuery()方法获取。如 String sql select * from product limit 0,10; SQLQuery query session.createSQLQuery(sql); ListObject[] query.list();
注意查询结果返回的是一个Object的数组。2、利用ResultMetaData对象来实现执行SQL语句但是如果过多地使用这种方法就会对系统的性能产生影响它将降低运行效率。通过addScalar()方法设置返回数据的类型可以减少ResultSetMetaData对象的使用而提高运行效率。如 String sql select * from product limit 0,10; SQLQuery sqlQuery session.CreateSQLQuery(); sqlQuery.addScalar(id,Hibernate.INTEGER); sqlQuery.addScalar(name,Hibernate.STRING); sqlQuery.addScalar(addre,Hibernate.STRING); sqlQuery.addScalar(des,Hibernate.STRING); ListObject[] list sqlQuery.list();
2、返回SQL查询的持久对象获取SQL查询的持久对象有三种方式实现方式1Hibernate不仅能把查询到的记录封装为包含多个Object数组的List对象返回还可以把每一条查询到的记录封装成持久对象后返回包含这些对象的List对象。如 String sql select * from product limit 0,10; SQLQuery sqlQuery session.CreateSQLQuery(); sqlQuery.addEntity(Product .class); ListProduct list sqlQuery.list(); 方式2使用大括号指定查询的字段然后通过SQLQuery对象对象的addEntity()方法关联SQL中的别名和持久化类确定要返回的List对象中的每个元素类型。如 String sql select{p.*} from Product p,Category c where p.category_idc.id; SQLQuery sqlQuery session.CreateSQLQuery(); sqlQuery.addEntity(p,Product.class); ListProduct list sqlQuery.list();
方式3同时使用SQLQuery对象的addScalar()方法和Transformers对象的aliasToBean()方法关联数据库的表与持久化类确定返回记录的各个字段与持久化类属性的对象对应关系。如String sql select p.id,p.name from product p,Category c where p.category_id c.id; SQLQuery sqlQuery session.createSQLQuery(sql); sqlQuery.addScalar(id,Hibernate.INTEGER)
.addScalar(name,Hibernate.STRING); sqlQuery.setResultTransformer(Transformers.aliasToBean(Product.class)); ListProduct list sqlQuery.list();