`

gethibernatetemplate find条件查询方法

阅读更多

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);

分享到:
评论

相关推荐

    getHibernateTemplate()查询

    以上介绍了通过`getHibernateTemplate()`方法执行查询的不同方式,包括简单的HQL查询、带有参数的查询、模糊查询以及基于实例对象的查询等。这些方法在实际开发中非常实用,可以帮助开发者更灵活地处理各种查询需求...

    getHibernateTemplate()使用方法

    该代码执行了一个条件查询,即获取名字为"test"的所有用户。 ### 3. `find(String queryString, Object[] values)` 此方法用于执行带有多个参数的HQL查询。 **示例:** ```java String hql = "from bean.User u ...

    hibernate模板类详解

    该方法用于执行HQL查询语句,返回一个对象列表。参数`queryString`表示HQL查询字符串。例如: ```java List&lt;User&gt; users = this.getHibernateTemplate().find("from bean.User"); ``` 这条代码会执行一个简单的HQL...

    Spring中常用的hql查询方法

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

    hql语言中的一些常用的方法

    - **单参数查询**:当查询条件只有一个时,可以使用带有单个参数的方法,例如:`this.getHibernateTemplate().find("from bean.User u where u.name=?", "test")`,这将返回所有名字为“test”的用户。 - **多参数...

    Spring中hql语句的常用方法

    1. **find(String queryString)**:此方法接受一个HQL字符串作为参数,返回所有符合条件的结果列表。 - 示例代码: ```java List&lt;User&gt; users = this.getHibernateTemplate().find("from bean.User"); ``` - ...

    Hibernate分页查询

    而`getAllRowCount`方法则通过`find`方法获取HQL查询结果的大小,即总记录数。 ```java public class MemberDaoImpl extends HibernateDaoSupport implements MemberDao { // 省略其他代码 public List ...

    Struts2,hibernate,Spring分页方法

    这里直接调用`getHibernateTemplate().find(hql).size()`来获取列表的大小,即记录总数。 在实现分页查询的过程中,`HibernateDaoSupport`起到了关键作用。它是Spring提供的一个支持类,使得我们可以在不直接接触`...

    图书查询-Java-Web程序设计教程-[共2页].pdf

    这里使用Hibernate ORM框架执行SQL查询,通过`getHibernateTemplate().find()`方法,构造一个模糊查询语句(`like '%'+name+'%'`),查找书名包含关键词的书籍,并将结果集转化为`List`返回。如果出现异常,返回`...

    hibernate API

    `find()`方法允许你执行HQL(Hibernate Query Language)查询,这是一种面向对象的查询语言,类似于SQL,但更适合于ORM环境。 虽然`HibernateTemplate`提供了很多便利,但它在处理复杂查询时可能需要创建内部类...

    hibernate 持久层优化

    - **`getHibernateTemplate().find`**:提供了一种更简洁的方式来执行查询,但在效率上略逊于前两种方法。 - **`jdbcTemplate.queryForList`**:通常用于执行JDBC级别的查询,效率介于上述几种方法之间。 在实际...

    SSH2分页算法的实现

    这里的关键在于`queryForPage`方法,它接受HQL查询语句、偏移量和查询长度作为参数,并返回查询结果列表。而`getAllRowCount`方法则用于获取符合条件的所有记录数量。 ##### 3.2 DAOImpl层实现 `BookInfoDaoImpl`...

    HibernateDaoSupport分页.

    这些方法都通过调用`getHibernateTemplate().executeFind()`来执行具体的分页查询操作。 ##### 2. Dao接口定义 为了更好地组织代码,我们通常会定义一个DAO(Data Access Object)接口,用来规范数据访问层的行为...

    常用的HQL语句!!!!

    `find()`方法会返回匹配条件的`PhUser`对象列表。 4. **HQL多表查询**: 多表查询涉及到两个或更多表的联合查询。例如,将`PhCorrelativeUnit`和`PhCorrelativeUnitFunction`两个表中的相关数据映射到一个Map中:...

    常用的HQL语句下载

    `getHibernateTemplate().find(hql)`执行查询并返回结果列表。 4. **HQL多表查询**: 多表查询在HQL中同样直观。第22行的查询演示了如何从`PhCorrelativeUnit`和`PhCorrelativeUnitFunction`两个表中选取数据,并...

    struts+spring+hibernate通用分页方法

    1. **获取总记录数**:通过查询数据库获取符合条件的所有记录总数。 2. **确定当前页码和每页记录数**:由客户端传入当前页码和每页记录数。 3. **计算起始位置**:根据总记录数、当前页码和每页记录数计算出需要...

    java 分页

    - `queryForPage` 方法用于执行分页查询,它接收HQL(Hibernate Query Language)作为查询条件,以及起始行号和每页显示的记录数,返回一个List类型的分页结果。 - `getAllRowCount` 方法用于获取满足查询条件的所有...

    SSH常见面试题文库.pdf

    使用 Hibernate 的方法可以通过 getHibernateTemplate 里面提供的 save,update,delete,find 等方法实现。同时,Spring 也提供了事务管理,用于管理 Hibernate 中的事务操作。 本文档总结了 SSH 面试题库,涵盖了...

    spring+hibernate详解

    `doInHibernate`方法接收一个`Session`参数,并在此基础上构建查询条件,返回符合条件的结果列表。 #### 五、总结 本文详细介绍了Spring与Hibernate集成的过程,包括如何配置`SessionFactory`、使用`...

Global site tag (gtag.js) - Google Analytics