`
zhaolb
  • 浏览: 27968 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

在spring中(getHibernateTemplate())HQL常用查询方式介绍

阅读更多
  在spring中(getHibernateTemplate())HQL常用查询方式介绍 收藏
一、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);



本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/aidesudi/archive/2009/11/01/4754378.aspx
分享到:
评论

相关推荐

    Spring中hql语句的常用方法

    本文档将详细介绍如何在Spring环境中运用HQL进行数据查询操作,包括基本查询、参数绑定以及命名查询等高级特性。 #### 一、基本查询方法 在Spring框架中,`HibernateTemplate`类提供了多种方法来执行HQL查询,这些...

    Spring中常用的hql查询方法

    在Spring框架与Hibernate技术结合使用时,HQL(Hibernate Query Language)作为对象查询语言被广泛应用于数据查询操作之中。本文将详细解析Spring框架中常用的HQL查询方法及其应用场景。 #### 一、find(String ...

    getHibernateTemplate

    在Spring MVC(S2SH,即Struts2、Spring和Hibernate的组合)架构中,`getHibernateTemplate()`常用于数据访问层(DAO,Data Access Object)以简化对数据库的操作。它提供了事务管理、异常转换等特性,使得开发更加...

    getHibernateTemplate()有模糊查询和 分页

    在给定的标题和描述中,提到的是`getHibernateTemplate()`的两个主要应用:模糊查询和分页。以下是这两个概念的详细解释: 1. **模糊查询**: 在Hibernate中,我们通常使用HQL(Hibernate Query Language)或SQL来...

    getHibernateTemplate()使用方法

    Spring框架进一步封装了Hibernate,提供了`getHibernateTemplate()`方法,使得在Spring环境中使用Hibernate变得更加便捷。本文将详细介绍`getHibernateTemplate()`的使用方法,并通过具体的代码示例帮助读者更好地...

    Spring 和hibernate集成自学笔记

    Spring的`HibernateTemplate`提供了多种方式来处理这些带参数的查询。 - **单个参数查询** ```java List&lt;User&gt; find(String queryString, Object value); // 示例:List&lt;User&gt; users = this....

    第24次课-1 Spring与Hibernate的整合

    Spring配置管理SessionFactory与数据库的连接,在实际的应用中,数据源会采用依赖注入的方式,传递给SessionFactory。 见beans-config_sh.xml 24.3 Spring对Hibernate的简化 24.3.1 概述 Hibernate的持久层访问步骤...

    Hibernate和spring集成

    在DAO层,我们可以继承`HibernateDaoSupport`,然后通过`getHibernateTemplate()`方法获取到`HibernateTemplate`实例,利用它来执行HQL或SQL语句。或者,直接使用`SessionFactory`创建`Session`对象进行操作。 5. ...

    继承 空指针 spring

    在IT行业中,Spring框架是Java应用开发中的一个关键组件,特别是在企业级应用中。它提供了丰富的功能,包括依赖注入(DI)、面向切面编程(AOP)、数据访问/对象关系映射(DAO/ORM)等。当我们谈论"继承 空指针 ...

    Hibernate和Spring集成分页方法

    接下来,我们将通过一个具体的例子来展示如何在Spring环境中使用Hibernate进行分页查询。示例代码片段如下: ```java public List findObjs(final String hql, final Page page) throws CommonServiceException { ...

    Struts2,hibernate,Spring分页方法

    在`MemberDaoImpl`实现类中,我们利用`HibernateTemplate`的`executeFind`方法,通过传入一个实现了`HibernateCallback`接口的匿名内部类来执行HQL查询,并设置分页参数。 2. `getAllRowCount`:此方法用于获取满足...

    SSh sql/hql 分页

    在软件开发中,分页是一项常用的技术,尤其在网络应用中为了提高用户体验及减轻服务器压力,分页功能尤为重要。Struts2 + Spring + Hibernate(简称SSH)是Java Web开发中常用的组合框架之一。本文将围绕“SSh sql/...

    hibernate模板类详解

    以上就是`HibernateTemplate`中常用的查询方法及其实现原理的详细介绍。这些方法极大地提高了开发效率,并且使得数据访问层的实现更加简洁和灵活。通过合理运用这些方法,开发者可以在实际项目中更加高效地处理数据...

    HibernateSpringStruts2整合开发中的一个分页显示方案.doc

    在`queryForPage`方法中,我们使用了`HibernateCallback`接口回调,通过`getHibernateTemplate().executeFind()`执行HQL查询并设置分页参数`setFirstResult`和`setMaxResults`。`getAllRowCount`方法则直接返回HQL...

    Spring使用技巧

    ### Spring使用技巧详解 ...总结来说,本文档详细介绍了在SSH框架中如何通过DAO执行SQL操作,以及Spring JDBC的使用技巧。这些技巧能够帮助开发者更高效地管理数据库连接,并简化对数据库的操作流程。

    spring struts2 hibernate 整合教程 详细入门

    接下来,我们将详细介绍如何在Spring + Hibernate + Struts2项目中实现分页功能。 ##### 4.1 DAO层设计 在DAO(Data Access Object)层,我们需要设计用于处理数据访问操作的接口和实现类。这里主要关注的是分页...

    struts+hibernate+spring

    本文将详细介绍如何在 Struts2 + Hibernate + Spring 的整合框架中实现分页功能。 #### 二、SSH框架简介 - **Struts2**:负责MVC模式中的控制器部分,提供丰富的标签库和拦截器机制,简化Web层开发。 - **...

    struts2+spring+hibernate分页显示完整代码

    `queryForPage` 方法通过`getHibernateTemplate().executeFind()`方法执行HQL查询,并利用`HibernateCallback`接口回调来设置查询的起始位置和最大结果数,从而实现分页。`getAllRowCount` 方法则直接返回HQL查询后...

    Hibernate分页查询

    在Web开发中,数据分页查询是一个常见的需求,它能够帮助用户更有效地浏览大量信息,而Hibernate作为一...通过这种方式,我们可以在Spring+Hibernate+Struts2的环境下轻松实现数据的分页查询,提高Web应用的用户体验。

Global site tag (gtag.js) - Google Analytics