前一例中BookHibernateDao的list方法用到了getSession().createQuery("HQL statement"); 返回一个Query, 这个Query是面向对象查询的最重要的接口.相当于jdbc中的statement,Query通过HQL和数据库交互.最简单的HQL: from Book 列出所有的Book对象. select到哪儿去了?这句话隐含select,可以这么写:
select b from Book b , 但是不能这么写: select * from Book
HQL可以带条件,比如 from Book b where b.author='sunxing007'.
HQL还可以带占位符:比如:
query = getSession().createQuery("from Book b where b.author=?");
query.setParameter(0, 'sunxing007');注意是从0开始, 和PreparedStatement不一样;
HQL还可以带命名参数,比如:
query = getSession().createQuery("from Book b where b.author=:authur");
query.setParameter("author", 'sunxing007');
以上的HQL都是写在代码中, 还可以把HQL写在配置文件中集中管理。下面采用这种方式来改进Book.hbm.xml和完善BookDao: