[转帖]关于DAO的问题_Tomcat, WebLogic及J2EE讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  Tomcat, WebLogic及J2EE讨论区 »
总帖数
1
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 3891 | 回复: 0   主题: [转帖]关于DAO的问题        下一篇 
Jenny
注册用户
等级:少校
经验:881
发帖:68
精华:0
注册:2013-1-15
状态:离线
发送短消息息给Jenny 加好友    发送短消息息给Jenny 发消息
发表于: IP:您无权察看 2013-1-17 9:39:41 | [全部帖] [楼主帖] 楼主

看到很多资料在使用spring框架后,为每个表对应的POJO写一个DAO接口,再写一个实现类,每个接口里都是简单的CRUD操作,感觉实在很麻烦
以前的项目里直接用struts+hibernate,有一个DbOperate类,来历不知,但它的CRUD方法可以对所有类操作,这样不是更简单?各位瞧瞧

public class DbOperate {
      public boolean save(Object obj) throws HibernateException {
            boolean result = false;
            Session session = SessionFactory.currentSession();
            if (obj != null) {
                  Transaction tx = null;
                  try {
                        tx = session.beginTransaction();
                        session.save(obj);
                        tx.commit();
                        result = true;
                  } catch (HibernateException e) {
                        if (tx != null) {
                              tx.rollback();
                              result = false;
                        }
                  } finally {
                  session.close();
                  return result;
            }
      }
      return result;
}
public void update(Object obj) throws HibernateException {
      Session session = SessionFactory.currentSession();
      if (obj != null) {
            Transaction tx = null;
            try {
                  tx = session.beginTransaction();
                  ////System.out.println("aaaa");
                  session.update(obj);
                  ////System.out.println("bbbb");
                  tx.commit();
                  ////System.out.println("cccc");
            } catch (HibernateException e) {
                  if (tx != null)
                  tx.rollback();
                  throw e;
            }
      }
      session.close();
}
public void delete(Object obj) throws HibernateException {
      Session session = SessionFactory.currentSession();
      if (obj != null) {
            Transaction tx = null;
            try {
                  tx = session.beginTransaction();
                  session.delete(obj);
                  tx.commit();
            } catch (HibernateException e) {
                  if (tx != null)
                  tx.rollback();
                  throw e;
            }
      }
      session.close();
}
public void saveOrUpdate(Object obj) throws HibernateException {
      Session session = SessionFactory.currentSession();
      if (obj != null) {
            Transaction tx = null;
            try {
                  tx = session.beginTransaction();
                  session.saveOrUpdate(obj);
                  tx.commit();
            } catch (HibernateException e) {
                  if (tx != null)
                  tx.rollback();
                  throw e;
            }
      }
      session.close();
}
public List find(String sql) throws HibernateException {
      Session session = SessionFactory.currentSession();
      List list = null;
      Transaction tx = null;
      try {
            tx = session.beginTransaction();
            Query query = session.createQuery(sql);
            list = query.list();
            tx.commit();
      } catch (HibernateException e) {
            if (tx != null)
            tx.rollback();
            throw e;
      }
      session.close();
      return list;
}
}




赞(0)    操作        顶端 
总帖数
1
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论