Hibernate学习笔记:HQL

前一例中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:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值