BBS项目笔记之八:hibernate底层查询的实现
2012-12-21 15:59
281 查看
主要是getHibernateTemplate()方法下边提供n多查询的方法 , 之前就用过load , 这次熟悉一下其他的方法
getHibernateTemplate.load() 存在延迟加载问题。
getHibernateTemplate.get() 不存在此问题,她是不采用lazy机制的。
1 当记录不存在时候,get方法返回null,load方法产生异常,即get()可以取空的数据集,但load()不行。
take a look at the Hibernate documentation (though I agree is not very explicit)--the HibernateTemplate is basically a wrapper around the native Hibernate API.
get() will return null if an object is not found while load() will always return a non-null object which is a proxy. If the underlying object does not exist, the proxy will thrown ObjectNotFoundException.
load() should be used when you are sure that the object exits while get() when
you're not.
2 load方法可以返回实体的代理类,get方法则返回真是的实体类
3 load方法可以充分利用hibernate的内部缓存和二级缓存中的现有数据,而get方法仅仅在内部缓存中
进行数据查找,如果没有发现数据則将越过二级缓存,直接调用SQL查询数据库。
4 也许别人把数据库中的数据修改了,load如何在缓存中找到了数据,则不会再访问数据库,而get则
会返回最新数据。
find支持模糊查询
this.getHibernateTemplate().find("from bean.User u where u.name like ?", "%test%");
find能传入k-v对 用于搜索, 返回用户名为test并且密码为123的所有User对象
this.getHibernateTemplate().find(hql, new String[]{"test", "123"});
findByNamedQuery(String queryName, Object[] value) 支持从mapping文件中读取配置
示例:
1、首先需要在User.hbm.xml中定义命名查询
<hibernate-mapping>
<class>......</class>
<query name="queryByNameAndPassword"><!--此查询被调用的名字-->
<![CDATA[
from bean.User u where u.name =? and u.password =?
]]>
</query>
</hibernate-mapping>
2、如下使用查询:
String[] values= new String[]{"test", "123"};
this.getHibernateTemplate().findByNamedQuery("queryByNameAndPassword" , values);
public String queryArticlesByUserOfReply() { this.searchArticles = this.articleDao.findArticlesByUserOfReply( this.reply.getReplyId().toString(), this.firstResult, this.maxResults); return "userArticle"; }
public List<Article> findArticlesByUserOfReply(String replyId, String firstResult, String maxResults) { Reply reply = (Reply) this.load(Reply.class, replyId); User user = reply.getUser(); return queryAllArticleByUser(user, firstResult, maxResults); }
getHibernateTemplate.load() 存在延迟加载问题。
getHibernateTemplate.get() 不存在此问题,她是不采用lazy机制的。
1 当记录不存在时候,get方法返回null,load方法产生异常,即get()可以取空的数据集,但load()不行。
take a look at the Hibernate documentation (though I agree is not very explicit)--the HibernateTemplate is basically a wrapper around the native Hibernate API.
get() will return null if an object is not found while load() will always return a non-null object which is a proxy. If the underlying object does not exist, the proxy will thrown ObjectNotFoundException.
load() should be used when you are sure that the object exits while get() when
you're not.
2 load方法可以返回实体的代理类,get方法则返回真是的实体类
3 load方法可以充分利用hibernate的内部缓存和二级缓存中的现有数据,而get方法仅仅在内部缓存中
进行数据查找,如果没有发现数据則将越过二级缓存,直接调用SQL查询数据库。
4 也许别人把数据库中的数据修改了,load如何在缓存中找到了数据,则不会再访问数据库,而get则
会返回最新数据。
find支持模糊查询
this.getHibernateTemplate().find("from bean.User u where u.name like ?", "%test%");
find能传入k-v对 用于搜索, 返回用户名为test并且密码为123的所有User对象
this.getHibernateTemplate().find(hql, new String[]{"test", "123"});
findByNamedQuery(String queryName, Object[] value) 支持从mapping文件中读取配置
示例:
1、首先需要在User.hbm.xml中定义命名查询
<hibernate-mapping>
<class>......</class>
<query name="queryByNameAndPassword"><!--此查询被调用的名字-->
<![CDATA[
from bean.User u where u.name =? and u.password =?
]]>
</query>
</hibernate-mapping>
2、如下使用查询:
String[] values= new String[]{"test", "123"};
this.getHibernateTemplate().findByNamedQuery("queryByNameAndPassword" , values);
public Object load(Class clazz, Serializable id) { return getHibernateTemplate().load(clazz, id); } public Object get(Class clazz, Serializable id) { return getHibernateTemplate().get(clazz, id); } public List findByNamedQuery(final String queryName) { return getHibernateTemplate().findByNamedQuery(queryName); } public List findByNamedQuery(final String queryName, final Object parameter) { return getHibernateTemplate().findByNamedQuery(queryName, parameter); } public List findByNamedQuery(final String queryName, final Object[] parameters) { return getHibernateTemplate().findByNamedQuery(queryName, parameters); } public List find(final String queryString) { return getHibernateTemplate().find(queryString); } public List find(final String queryString, final Object[] parameters) { return getHibernateTemplate().find(queryString, parameters); }
相关文章推荐
- BBS项目笔记之一:Spring+Hibernate实现Dao层
- 网上图书商城项目学习笔记-025分类管理模块分析及查询所有分类实现
- BBS项目笔记之五:BBS论坛首页的实现
- BBS项目笔记之九:js实现动态的导航
- BBS项目笔记之十:登录和注册模块的前台实现
- BBS项目笔记之二:struts2标签前台实现分页的复用
- BBS项目笔记之七:Ajax实现帖子回复
- BBS项目笔记之四:搜索的后台实现
- [原创]java WEB学习笔记93:Hibernate学习之路---Hibernate 缓存介绍,缓存级别,使用二级缓存的情况,二级缓存的架构集合缓存,二级缓存的并发策略,实现步骤,集合缓存,查询缓存,时间戳缓存
- 最近项目中用hibernate分页查询的底层方法
- 最近项目中用hibernate分页查询的底层方法
- hibernate 实现多表连接查询(转载)
- JSP-Servlet实现网上BBS项目小案例
- Hibernate实现分页查询的原理分析
- Hibernate 注册登录,对数据库实现增删改查,及根据用户名来查询数据库
- 项目分析笔记(2)---聊天室项目分析与实现(2008.6.12)
- 六种方式实现hibernate查询,及IDE推荐
- mybatis学习笔记二mybatis结合spring mvc实现(用户登录,数据查询)
- Spring boot + maven + hibernate 实现数据库连接、查询
- hibernate实现多表联合查询