gpt4 book ai didi

java - Hibernate 4 - 调用 DAO 和初始化 sessionFactory bean

转载 作者:行者123 更新时间:2023-11-29 05:51:53 25 4
gpt4 key购买 nike

我正在将我的旧程序更新到 Spring 3.2 和 Hibernate 4,并且在使用 sessionFactory 时遇到了一些困难(我之前使用的是 hibernateTemplate)。

  1. 我不认为我访问 DAO 的方式是最好的方式,但我不知道还有什么方法可以让它发挥作用。如果我简单创建 DAO 对象 (CSSDAO d = new CSSDAOImpl();),sessionFactory 始终为空。如果我按照下面的方式使用它,它就可以工作。调用 DAO 方法的正确方法是什么? (请忽略 Controller 的 MVC 部分,我知道它需要自己的工作)

  2. 我正在 DAO 中的每个方法中打开一个新 session 。我知道这是不正确的,因为我应该获得当前 session 。但是每次我尝试获取当前 session 时,它都说不存在。 session 如何第一次“初始化”?我认为它会根据 XML 配置注入(inject)它,但这似乎并没有在这里做任何事情。有什么想法吗?

hibernate-cfg.xml

    <?xml version="1.0" encoding="UTF-8"?>


<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.0.xsd">

<bean id="myDataSource"
class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName" value="org.apache.derby.jdbc.EmbeddedDriver"></property>
<property name="url" value="jdbc:derby:C:\Users\Steven\MyDB"></property>
</bean>

<bean id="sessionFactory"
class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
<property name="packagesToScan" value="net.form" />
<property name="dataSource" ref="myDataSource"></property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">org.hibernate.dialect.DerbyTenSevenDialect
</prop>
<prop key="hibernate.show_sql">true</prop>
</props>
</property>
<property name="annotatedClasses">
<list>
<value>net.form.StyleChooser</value>
</list>
</property>
</bean>

<bean id="transactionManager"
class="org.springframework.orm.hibernate4.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory" />
</bean>

<tx:annotation-driven transaction-manager="transactionManager" />

<bean id="CSSDAO" class="dao.CSSDAOImpl">
<property name="sessionFactory" ref="sessionFactory" />
</bean>

</beans>

DAO:

package dao;

import java.util.List;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.transaction.annotation.Transactional;

import net.form.StyleChooser;

public class CSSDAOImpl implements CSSDAO {

private SessionFactory sessionFactory;

@Autowired
public void setSessionFactory(SessionFactory sessionFactory) {
this.sessionFactory = sessionFactory;
}

@Transactional
public List selectAllCSS() {
Session session = sessionFactory.openSession();
Transaction tx = session.beginTransaction();
List l = session.createCriteria(StyleChooser.class).list();
session.flush();
tx.commit();
return l;
}

@Transactional
public StyleChooser selectCSSById(Integer ID) {
Session session = sessionFactory.openSession();
Transaction tx = session.beginTransaction();
StyleChooser sc = (StyleChooser) session.get(StyleChooser.class, ID);
session.flush();
tx.commit();
return sc;
}

@Transactional
public Integer insertCSS(StyleChooser insertCSS) {
Session session = sessionFactory.openSession();
Transaction tx = session.beginTransaction();
Integer id = (Integer) session.save(insertCSS);
session.flush();
tx.commit();
return id;
}

@Transactional
public void deleteCSS(Integer CSSId) {
Session session = sessionFactory.openSession();
Transaction tx = session.beginTransaction();
StyleChooser sc = (StyleChooser) session.get(StyleChooser.class, CSSId);
session.delete(sc);
session.flush();
tx.commit();
}

@Transactional
public void updateCSS(StyleChooser cssWithNewValues) {
Session session = sessionFactory.openSession();
Transaction tx = session.beginTransaction();
session.update(cssWithNewValues);
session.flush();
tx.commit();
}
}

访问 DAO...

package net.controllers;

import java.util.List;
import javax.servlet.http.HttpServletRequest;
import net.form.StyleChooser;
import org.springframework.beans.factory.BeanFactory;
import org.springframework.beans.factory.xml.XmlBeanFactory;
import org.springframework.core.io.FileSystemResource;
import org.springframework.core.io.Resource;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.multiaction.MultiActionController;
import dao.CSSDAOImpl;

@Controller
@RequestMapping("/stylechoosertable.html")
public class IndexController extends MultiActionController {

Resource resource = new FileSystemResource(
"C:/Users/Steven/Desktop/Programming/workspace/CSSGeneratorHibernate4/WebContent/WEB-INF/hibernate.cfg.xml");
BeanFactory beanFactory = new XmlBeanFactory(resource);
CSSDAOImpl dao = (CSSDAOImpl) beanFactory.getBean("CSSDAO");

@RequestMapping(method = RequestMethod.GET)
public ModelAndView showIndex(HttpServletRequest request) throws Exception {
List<StyleChooser> styleChooser = dao.selectAllCSS();
return new ModelAndView("stylechoosertable", "styleChooser", styleChooser);
}
}

最佳答案

很少观察:

  1. 在您的检索方法中,不应使用事务,即它们应该是非事务性的。

  2. 添加<tx:annotation-driven transaction-manager="transactionManager"/>在您的配置中识别交易注释。

  3. 如果您使用 @Transactional注释则不需要使用编程事务。在 @Transactional 中添加传播属性注释为 @Transactional(propagation=Propagation.REQUIRED)并将事务管理留给 Hibernate。

  4. 第一次需要打开 session ,如果没有关闭,下次可以使用相同的 session 。为了获得 session , 最好使用如下实用方法:

    private Session getSession(SessionFactory sessionFactory){
    Session session = null;
    try{
    session = sessionFactory.getCurrentSession();
    }catch(HibernateException hex){
    hex.printStackTrace();
    }
    if(session == null && !session.isClosed()){
    session = sessionFactory.openSession();
    }
    }

这样,您将获得 session (如果可用)并打开,否则打开一个新 session 。

关于java - Hibernate 4 - 调用 DAO 和初始化 sessionFactory bean,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13576777/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com