Spring的HibernateDaoSupport及用hibernate执行原生SQL

Spring为Hibernate的DAO提供工具类:HibernateDaoSupport。该类主要提供了两个方法: 
(1)public final HibernateTemplate getHibernateTemplate() 
(2)public final void setSessionFactory(SessionFactory sessionFactory) 
其中,

(1)setSessionFactory方法接收来自Spring的applicationContext的依赖注入,接收了在Spring中配置的SessionFactory;

(2)getHibernateTemplate方法用来利用刚才的SessionFactory生成Session,来完成数据库的访问。 

 

 

执行原生SQL(这个类要继承Spring的HibernateDaoSupport类):

(1)查询

[java]  view plain copy
  1. HibernateTemplate tmpl = getHibernateTemplate();  
  2. return tmpl.execute(new HibernateCallback<List<String>>() {  
  3.     @SuppressWarnings("unchecked")  
  4.     @Override  
  5.     public List<String> doInHibernate(Session session)  
  6.         throws HibernateException, SQLException {  
  7.         SQLQuery query = session.createSQLQuery("select name from userinfo where userid=?");  
  8.         query.addScalar("name", Hibernate.STRING);   //返回值类型  
  9.         query.setInteger(0, Integer.parseInt(userId)); //输入参数  
  10.         List results = query.list();  //因为只有查询一个列,所以返回的List是List<Object>  
  11.         return (List<String>)results;  
  12.     }  
  13. });  

[java]  view plain copy
  1. HibernateTemplate tmpl = getHibernateTemplate();  
  2. return tmpl.execute(new HibernateCallback<List<Object[]>>() {  
  3.     @SuppressWarnings("unchecked")  
  4.     @Override  
  5.     public List<Object[]> doInHibernate(Session session)  
  6.         throws HibernateException, SQLException {  
  7.         SQLQuery query = session.createSQLQuery("select name,desc from userinfo where userid=?);  
  8.         query.addScalar("name", Hibernate.STRING);  
  9.         query.addScalar("desc", Hibernate.STRING);  
  10.         query.setInteger(0, Integer.parseInt(userId));  
  11.         List results = query.list();  //有多个列,返回的是List<Object[]>  
  12.         for (int i = 0; i < results.size(); i++) {  
  13.             Object[] row = (Object[]) results.get(i);  
  14.             String name = (String) row[0];  
  15.             String desc = (String) row[1];  
  16.             System.out.println("name=" + name + ";desc=" + desc);  
  17.         }  
  18.         return (List<Object[]>)results;  
  19.     }  
  20. });  

(2)插入、更新、删除

[java]  view plain copy
  1.         HibernateTemplate tmpl = getHibernateTemplate();  
  2.         tmpl.execute(new HibernateCallback<Object>() {  
  3.             @Override  
  4.             public Object doInHibernate(Session session)  
  5.                 throws HibernateException, SQLException {  
  6.                 session.doWork(new Work() {  
  7.                     @Override  
  8.                     public void execute(Connection conn) throws SQLException {  
  9.                         PreparedStatement pstat = conn  
  10.                                 .prepareStatement("insert into userinfo(userid,name,desc) values(?,?,?)");  
  11.                         for (int i = 0; i < data.size(); i++) {  
  12.                             List<String> row = data.get(i);  
  13.                             String userid = row.get(0)  
  14.                             String name = row.get(1);  
  15.                             String desc = row.get(2);  
  16.                             pstat.setInt(1, userId);  
  17.                             pstat.setString(2, name);  
  18.                             pstat.setString(3, desc);  
  19.                             pstat.addBatch();  
  20.                         }  
  21.                         pstat.executeBatch();  
  22.                     }  
  23.                 });  
  24.                 return null;  
  25.             }  
  26.         });  
  27. 这里面data是一个List<List<String>>的二维表格形式  

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值