打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
Hibernate中hibernateTemplate()方法总结

1:get/load存取单条数据

 public Teacher getTeacherById(Long id) {          return (Teacher)this.hibernateTemplate.get(Teacher.class, id);  }        public Teacher getTeacherById(Long id) {          return (Teacher)this.hibernateTemplate.load(Teacher.class, id);  } 

2:find/iterate查询操作

 public Iterator getTeachersByAge(int age) {      Iterator iterator = null;            //使用find方法      List list = (List)this.hibernateTemplate().find("from Teacher t where t.age>?", new Integer(age));      iterator = list.iterator();            //使用iterator方法      iterator = this.hibernateTemplate().iterate("from Teacher t where t.age>?", new Integer(age));            return iterator;  }  

find和iterato的区别主要是iterate采用了N+1次查询,对于大批量查询,比如查询10000条记录,那么iterate就要执行10000+1次查询,find和iterate应根据具体的实际情况来使用,对于频繁的写操作对象,应使用find查询,而对于一些只读的数据对象,应使用iterate操作,因为iterate操作使用了Hibernate的缓存机制

3:save/update/saveOrUpdate/delete 保存/更新/删除操作  

      public void save(Teacher teacher) {          this.hibernateTemplate.save(teacher);      }             public void update(Teacher teacher) {          this.hibernateTemplate.update(teacher);      }            public void update(Teacher teacher) {          this.hibernateTemplate.saveOrUpdate(teacher);      }             public void delete(Teacher teacher) {          this.hibernateTemplate.delete(teacher);      }  

4:bulkUpdate批量删除或者更新

bulkUpdate提供了批量删除和更新,直接转换为相应的update/delete SQL进行批量删除和更新

 public void batchDelete(String name, int age) {          this.hibernateTemplate.bulkUpdate("delete Teacher where name=? and age = ?", new Object[]{name, age});   }  public void batchDelete(String name, String newName) {          this.hibernateTemplate.bulkUpdate("update Teacher set name=? where name=?", new Object[]{newName, name});  }  

此时要注意的一个问题是,使用bulkUpdate操作,必须手工清除相关对象在Hibernate中的缓存(包括一级缓存和二级缓存)

 

****find相关方法总结

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

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
HibernateTemplate常用方法总结
Hibernate中如何使用count(*)取得表中记录总数
在myeclipse下整合spring和hibernate
hibernate 泛型DAO
Spring整合Hibernate中对HibernateTemplate的思考
HibernateTemplate.execute(HibernateCallback action)回调方式
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服