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)
 
 
             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);
 示例:
        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"};

转载于:https://www.cnblogs.com/baoendemao/p/3804771.html

getHibernateTemplate()(Spring中常用的hql查询方法)相关推荐

  1. java hql查询_Spring 中常用的hql查询方法(getHibernateTemplate())(转)

    示例:this.getHibernateTemplate().find("from bean.User"); 返回所有User对象 二.find(String queryStrin ...

  2. django中常用的数据查询方法

    5.2 数据查询 要从数据库检索数据,首先要获取一个*查询集***(QuerySet),查询集表示从数据库获取的对象集合,它可以有零个,一个或多个过滤器.返回查询集的方法,称为过滤器,过滤器根据给定的 ...

  3. 声明式事务、Spring 中常用注解、Ajax

    五. 声明式事务 编程式事务: 1.1 由程序员编程事务控制代码. 1.2 OpenSessionInView 编程式事务 声明式事务: 先引入依赖 <dependency><gro ...

  4. 学习笔记【Spring中常用的设计模式】

    文章目录 简介 一. Spring用到的设计模式类别 1. 创建型模式 2. 结构性模式 3. 行为型模式 二. 设计模式详解 1. 工厂模式 1.1 简单工厂模式 1.2 工厂方法模式 1.3 抽象 ...

  5. 08-数组中常用的属性及方法

    08-数组中常用的属性及方法 创建: 使用 JavaScript 关键词 new 使用数组文本创建 //数组中的方法: toString() 把数组转换为数组值(逗号分隔)的字符串. join() 方 ...

  6. java中常用的包、类、以及包中常用的类、方法、属性----sql和text\swing

    java中常用的包.类.以及包中常用的类.方法.属性 常用的包 java.io.*; java.util.*; java.lang.*; java.sql.*; java.text.*; java.a ...

  7. Python中常用的内置方法

    Python中常用的内置方法: 比较大小.求和 如下所示: 代码块: #枚举:返回索引值和对应的value值for i,v in enumerate('westos'):print(i,v)#zips ...

  8. ML:模型训练/模型评估中常用的两种方法代码实现(留一法一次性切分训练和K折交叉验证训练)

    ML:模型训练/模型评估中常用的两种方法代码实现(留一法一次性切分训练和K折交叉验证训练) 目录 模型训练评估中常用的两种方法代码实现 T1.留一法一次性切分训练 T2.K折交叉验证训 模型训练评估中 ...

  9. 数组中常用的高阶方法

    一.操作方法 1.concat 如果传递的参数是一个数组或者多个数组,那么会将多个数组的每一个项都添加到原来的数组后面,然后返回这个数组,原数组不变. 例如: 2.slice slice方法接受两个参 ...

最新文章

  1. 全国所有省市县地理坐标Json格式
  2. windows xp开机音乐7秒_(老旧电脑的福音)win 10 ltsb2015开机只要7秒
  3. javaScript实现归并排序
  4. tensorflow--variable_scope
  5. Quartz- Quartz API以及Jobs 和Triggers介绍
  6. 机器人学习--粒子滤波及其在定位中的应用
  7. visual foxpro 程序员指南_如何平衡工作和生活的关系?程序员归来依旧是少年的好方法...
  8. CODE[VS] 3411 洪水
  9. 查看计算机上隐藏用户,隐藏或显示 InetOrgPerson 对象类 - Windows Server | Microsoft Docs...
  10. htmlunit抓取js执行后的网页源码
  11. L1-051 打折-PAT团体程序设计天梯赛GPLT
  12. Hadoop简单安装配置
  13. delphi LPT1端口打印与开钱箱
  14. WLAN无线技术基本概念(802.11a/b/g/n/ac/ax区别,频段,信道概念)
  15. js 入门基础(一)
  16. 剑指offer-二叉树中值等于某个数的路径
  17. 如何自动隐藏win10任务栏
  18. java iw_java.lang.IndexOutOfBoundsException
  19. OpenCv-C++-深度神经网络(DNN)模块-使用SSD模型实现对象检测
  20. 木木机器人tf卡_Microsoft 微软 L5V-00022 Sculpt Ergonomic 人体工程学无线键鼠套装

热门文章

  1. libuv tcp client
  2. go 访问数据库mysql基础
  3. 手动配置apache php,windows下手动搭建apache和php环境
  4. [大学回忆录-思想]再谈我的专业技能
  5. github java开源项目经验_Java 开源项目 GitHub 趋势周报 20201230
  6. 【Elasticsearch】ARS提升检索吞吐率
  7. 【Elasticsearch】 es Bootstrap Checks Failed
  8. 【mac】mac 安装 RibbitMQ 报错 Error when reading /Users/lcc/.erlang.cookie: eacces
  9. 【clickhouse】clickhouse表引擎之CollapsingMergeTree
  10. 【hortonworks/registry】诡异问题之启动了却无法访问