您的位置:首页 > 其它

BBS项目笔记之八:hibernate底层查询的实现

2012-12-21 15:59 281 查看
主要是getHibernateTemplate()方法下边提供n多查询的方法 , 之前就用过load , 这次熟悉一下其他的方法

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);
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: