- 浏览: 127848 次
- 性别:
- 来自: 武汉
文章分类
最新评论
-
l85912502:
Tomcat虽然是跨平台的,但是,如果想让Tomcat运行到最 ...
tcnative-1.dll文件 -
iyangxin:
不错不错!
MyEclipse 7.0下载 + 汉化 + doc汉化 -
jingguohao:
憋的久了 就想释放了。。。
为什么一提到裸*聊、艳照 网民就兴奋? -
wsdsgfuqiang:
cqh520llr 写道动态模板怎么给模板加完整的一行
JAVA操作Excel,读取Excel模板动态写入数据并生成Excel -
cqh520llr:
jb,动态模板懂吗?
JAVA操作Excel,读取Excel模板动态写入数据并生成Excel
Spring中常用的hql查询方法(getHibernateTemplate())
---------------------------------
一、find(String queryString);
示例:this.getHibernateTemplate().find("from bean.User");
返回所有User对象
二、find(String queryString , Object value);
示例:this.getHibernateTemplate().find("from bean.User u where u.name=?", "test");
或模糊查询:this.getHibernateTemplate().find("from bean.User u where u.name like ?", "%test%");
返回name属性值为test的对象(模糊查询,返回name属性值包含test的对象)
三、find(String queryString, Object[] values);
示例:String hql= "from bean.User u where u.name=? and u.password=?"
this.getHibernateTemplate().find(hql, new String[]{"test", "123"});
返回用户名为test并且密码为123的所有User对象
---------------------------------
四、findByExample(Object exampleEntity)
示例:
User u=new User();
u.setPassword("123");//必须 符合的条件但是这两个条件时并列的(象当于sql中的and)
u.setName("bb");
list=this.getHibernateTemplate().findByExample(u,start,max);
返回:用户名为bb密码为123的对象
五、findByExample(Object exampleEntity, int firstResult, int maxResults)
示例:
User u=new User();
u.setPassword("123");//必须 符合的条件但是这两个条件时并列的(象当于sql中的and)
u.setName("bb");
list=this.getHibernateTemplate().findByExample(u,start,max);
返回:满足用户名为bb密码为123,自start起共max个User对象。(对象从0开始计数)
---------------------------------------------------
六、findByNamedParam(String queryString , String paramName , Object value)
使用以下语句查询:
String queryString = "select count(*) from bean.User u where u.name=:myName";
String paramName= "myName";
String value= "xiyue";
this.getHibernateTemplate().findByNamedParam(queryString, paramName, value);
System.out.println(list.get(0));
返回name为xiyue的User对象的条数
七、findByNamedParam(String queryString , String[] paramName , Object[] value)
示例:
String queryString = "select count(*) from bean.User u where u.name=:myName and u.password=:myPassword";
String[] paramName= new String[]{"myName", "myPassword"};
String[] value= new String[]{"xiyue", "123"};
this.getHibernateTemplate().findByNamedParam(queryString, paramName, value);
返回用户名为xiyue密码为123的User对象
八、findByNamedQuery(String queryName)
示例:
1、首先需要在User.hbm.xml中定义命名查询
<hibernate-mapping>
<class>......</class>
<query name="queryAllUser"><!--此查询被调用的名字-->
<![CDATA[
from bean.User
]]>
</query>
</hibernate-mapping>
2、如下使用查询:
this.getHibernateTemplate().findByNamedQuery("queryAllUser");
九、findByNamedQuery(String queryName, Object value)
示例:
1、首先需要在User.hbm.xml中定义命名查询
<hibernate-mapping>
<class>......</class>
<query name="queryByName"><!--此查询被调用的名字-->
<![CDATA[
from bean.User u where u.name = ?
]]>
</query>
</hibernate-mapping>
2、如下使用查询:
this.getHibernateTemplate().findByNamedQuery("queryByName", "test");
十、findByNamedQuery(String queryName, Object[] value)
示例:
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);
十一、findByNamedQueryAndNamedParam(String queryName, String paramName, Object value)
示例:
1、首先需要在User.hbm.xml中定义命名查询
<hibernate-mapping>
<class>......</class>
<query name="queryByName"><!--此查询被调用的名字-->
<![CDATA[
from bean.User u where u.name =:myName
]]>
</query>
</hibernate-mapping>
2、如下使用查询:
this.getHibernateTemplate().findByNamedQuery("queryByName" , "myName", "test");
十二、findByNamedQueryAndNamedParam(String queryName, String[] paramName, Object[] value)
示例:
1、首先需要在User.hbm.xml中定义命名查询
<hibernate-mapping>
<class>......</class>
<query name="queryByNameAndPassword"><!--此查询被调用的名字-->
<![CDATA[
from bean.User u where u.name =:myName and u.password=:myPassword
]]>
</query>
</hibernate-mapping>
2、如下使用查询:
String[] names= new String[]{"myName", "myPassword"};
String[] values= new String[]{"test", "123"};
this.getHibernateTemplate().findByNamedQuery("queryByNameAndPassword" , names, values);
十三、findByValueBean(String queryString , Object value);
示例:
1、定义一个ValueBean,属性名必须和HSQL语句中的:后面的变量名同名,此处必须至少有两个属性,分别为myName和myPassword,使用setter方法设置属性值后
ValueBean valueBean= new ValueBean();
valueBean.setMyName("test");
valueBean.setMyPasswrod("123");
2、
String queryString= "from bean.User u where u.name=:myName and u.password=:myPassword";
this.getHibernateTemplate().findByValueBean(queryString , valueBean);
十四、findByNamedQueryAndValueBean(String queryName , Object value);
示例:
1、首先需要在User.hbm.xml中定义命名查询
<hibernate-mapping>
<class>......</class>
<query name="queryByNameAndPassword"><!--此查询被调用的名字-->
<![CDATA[
from bean.User u where u.name =:myName and u.password=:myPassword
]]>
</query>
</hibernate-mapping>
2、定义一个ValueBean,属性名必须和User.hbm.xml命名查询语句中的:后面的变量名同名,此处必须至少有两个属性,分别为myName和myPassword,使用setter方法设置属性值后
ValueBean valueBean= new ValueBean();
valueBean.setMyName("test");
valueBean.setMyPasswrod("123");
3、
String queryString= "from bean.User u where u.name=:myName and u.password=:myPassword";
this.getHibernateTemplate().findByNamedQueryAndValueBean("queryByNameAndPassword", valueBean);
发表评论
-
大数据学习0基础葵花宝典
2017-03-16 10:09 457BIGDATA葵花宝典 1、虚拟机安装CentOS VMwar ... -
SQL 左外连接,右外连接,全连接,内连接
2010-08-29 22:22 1190联接条件可在 FROM ... -
图解SSH框架配置步骤
2010-08-27 12:02 1117现在开发的一个项目使用S2SH框架,配置环境用了一两天,现在把 ... -
在JSP中配置FCKeditor 2.6.4
2010-01-07 11:21 11551.FCKeditor 介绍FCKeditor 这个开源的HT ... -
struts2 文件下载 修正中文问题
2009-11-06 17:28 1754在BlogJava上已经有一位作者阐述了文件上传的问题,地址是 ... -
MyEclipse 7.0下载 + 汉化 + doc汉化
2009-03-31 16:17 22263MyEclipse7.0 下面是官网就 ... -
每位新手都要搞懂弄明白的事
2009-03-12 16:29 793对于这个系列里的问题,每个学Java的人都应该搞懂。当然,如果 ... -
关于Oracle学习以及DBA工作机会
2008-12-29 16:59 1081最近有很多朋友发邮件或者在QQ/MSN上向我咨询关于学习和工作 ... -
DBA 2.0的时代与 Oracle促进的变革
2008-12-27 11:29 785这几天看到Kamus和Piner分 ... -
Oracle10g RAC安装手册2
2008-07-21 09:34 6398第五部分 安装配置Oracle RAC5.1 配置环境变量5. ... -
Oracle10g RAC安装手册1
2008-07-21 09:33 4611概述本手册在以下环境 ... -
JAVA操作Excel,读取Excel模板动态写入数据并生成Excel
2008-07-05 10:24 5039现在来看看如何读取Excel模板然后把动态数据写入到 ... -
配置AWSTATS用于分析Tomcat的访问日志
2008-06-30 11:20 3414配置AWSTATS用于分析Tomcat ... -
ajax中实现提示框
2008-06-26 22:11 1082Color=#cccccc cellSpacing=0 ce ... -
提高Java水平的十大技术
2008-06-26 22:08 1008本文列出了当今计算机软件开发和应用领域最重要十种关键技术排名, ... -
Java技术开源搜索引擎
2008-06-24 22:26 2027Egothor Egothor是一个用Java编写的开源而高 ... -
Spring MVC与struts比较
2008-06-21 10:20 5265下面的内容只是对web层的对比,很浮浅,spring的东西, ... -
Seam能否取代Struts?
2008-06-13 15:12 1481本文分析了JBoss Seam ... -
Eclipse快捷键大全(转载)
2008-06-13 14:48 875Ctrl+1 快速修复(最经典 ... -
最吸引眼球的网站——钱包网
2008-05-27 13:58 1114众所周知,今年是web2.0在互联网上大行其道的一年,涌现出众 ...
相关推荐
以上介绍了通过`getHibernateTemplate()`方法执行查询的不同方式,包括简单的HQL查询、带有参数的查询、模糊查询以及基于实例对象的查询等。这些方法在实际开发中非常实用,可以帮助开发者更灵活地处理各种查询需求...
该代码执行了一个条件查询,即获取名字为"test"的所有用户。 ### 3. `find(String queryString, Object[] values)` 此方法用于执行带有多个参数的HQL查询。 **示例:** ```java String hql = "from bean.User u ...
该方法用于执行HQL查询语句,返回一个对象列表。参数`queryString`表示HQL查询字符串。例如: ```java List<User> users = this.getHibernateTemplate().find("from bean.User"); ``` 这条代码会执行一个简单的HQL...
### Spring框架中HQL查询方法详解 在Spring框架与Hibernate技术结合使用时,HQL(Hibernate Query Language)作为对象查询语言被广泛应用于数据查询操作之中。本文将详细解析Spring框架中常用的HQL查询方法及其应用...
- **单参数查询**:当查询条件只有一个时,可以使用带有单个参数的方法,例如:`this.getHibernateTemplate().find("from bean.User u where u.name=?", "test")`,这将返回所有名字为“test”的用户。 - **多参数...
1. **find(String queryString)**:此方法接受一个HQL字符串作为参数,返回所有符合条件的结果列表。 - 示例代码: ```java List<User> users = this.getHibernateTemplate().find("from bean.User"); ``` - ...
而`getAllRowCount`方法则通过`find`方法获取HQL查询结果的大小,即总记录数。 ```java public class MemberDaoImpl extends HibernateDaoSupport implements MemberDao { // 省略其他代码 public List ...
这里直接调用`getHibernateTemplate().find(hql).size()`来获取列表的大小,即记录总数。 在实现分页查询的过程中,`HibernateDaoSupport`起到了关键作用。它是Spring提供的一个支持类,使得我们可以在不直接接触`...
这里使用Hibernate ORM框架执行SQL查询,通过`getHibernateTemplate().find()`方法,构造一个模糊查询语句(`like '%'+name+'%'`),查找书名包含关键词的书籍,并将结果集转化为`List`返回。如果出现异常,返回`...
`find()`方法允许你执行HQL(Hibernate Query Language)查询,这是一种面向对象的查询语言,类似于SQL,但更适合于ORM环境。 虽然`HibernateTemplate`提供了很多便利,但它在处理复杂查询时可能需要创建内部类...
- **`getHibernateTemplate().find`**:提供了一种更简洁的方式来执行查询,但在效率上略逊于前两种方法。 - **`jdbcTemplate.queryForList`**:通常用于执行JDBC级别的查询,效率介于上述几种方法之间。 在实际...
这里的关键在于`queryForPage`方法,它接受HQL查询语句、偏移量和查询长度作为参数,并返回查询结果列表。而`getAllRowCount`方法则用于获取符合条件的所有记录数量。 ##### 3.2 DAOImpl层实现 `BookInfoDaoImpl`...
这些方法都通过调用`getHibernateTemplate().executeFind()`来执行具体的分页查询操作。 ##### 2. Dao接口定义 为了更好地组织代码,我们通常会定义一个DAO(Data Access Object)接口,用来规范数据访问层的行为...
`find()`方法会返回匹配条件的`PhUser`对象列表。 4. **HQL多表查询**: 多表查询涉及到两个或更多表的联合查询。例如,将`PhCorrelativeUnit`和`PhCorrelativeUnitFunction`两个表中的相关数据映射到一个Map中:...
`getHibernateTemplate().find(hql)`执行查询并返回结果列表。 4. **HQL多表查询**: 多表查询在HQL中同样直观。第22行的查询演示了如何从`PhCorrelativeUnit`和`PhCorrelativeUnitFunction`两个表中选取数据,并...
1. **获取总记录数**:通过查询数据库获取符合条件的所有记录总数。 2. **确定当前页码和每页记录数**:由客户端传入当前页码和每页记录数。 3. **计算起始位置**:根据总记录数、当前页码和每页记录数计算出需要...
- `queryForPage` 方法用于执行分页查询,它接收HQL(Hibernate Query Language)作为查询条件,以及起始行号和每页显示的记录数,返回一个List类型的分页结果。 - `getAllRowCount` 方法用于获取满足查询条件的所有...
使用 Hibernate 的方法可以通过 getHibernateTemplate 里面提供的 save,update,delete,find 等方法实现。同时,Spring 也提供了事务管理,用于管理 Hibernate 中的事务操作。 本文档总结了 SSH 面试题库,涵盖了...
`doInHibernate`方法接收一个`Session`参数,并在此基础上构建查询条件,返回符合条件的结果列表。 #### 五、总结 本文详细介绍了Spring与Hibernate集成的过程,包括如何配置`SessionFactory`、使用`...