2

hibernate 4 と Spring 3 を使用して単純な DAO を実装しようとしています。

データベースの行を保存または削除しようとすると、トランザクションが保持されません。データベースへの保存がどのように機能しないかを示すコードをいくつか含めました。

StockEntityDTO を db に保存しようとする junit テストがあります。

@RunWith(SpringJUnit4ClassRunner.class)
public class StocksDAOImplTest extends
    AbstractTransactionalJUnit4SpringContextTests {

@Autowired
protected StocksDAO stockDao;


@Test
public void shouldInsertIntoDatabase() {
    BigDecimal price = new BigDecimal(653.50);
    StockEntityDTO savedStock = new StockEntityDTO("GOOG", price, "google");
    stockDao.create(savedStock);
    StockEntityDTO retrievedStock = stockDao.getById(savedStock.getId());
    assertEquals(savedStock, retrievedStock);
}

テストはパスしますが、予期される行 (1、「GOOG」、653.50、「google」) はデータベースに保持されません。

DAO は次のようになります。

@Transactional
public abstract class AbstractHibernateDAO<T extends Serializable> {

private Class<T> clazz;


@Resource(name = "sessionFactory")
private SessionFactory sessionFactory;


public void setClazz(final Class<T> clazzToSet) {
    this.clazz = clazzToSet;
}


public void create(final T entity) {
    Session session = this.getCurrentSession();
    session.save(entity);

}

アプリケーションのコンテキスト:

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

<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
    <property name="driverClassName" value="oracle.jdbc.OracleDriver" />
    <property name="url" value="jdbc:oracle:thin:@localhost:1521:orcl" />
    <property name="username" value="gtp" />
    <property name="password" value="gtp" />
</bean>

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

<bean id="sessionFactory"
    class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
    <property name="dataSource" ref="dataSource" />
    <property name="packagesToScan" value="com.ubs.gtp.data.domain" />
    <property name="hibernateProperties">
        <props>
            <prop key="hibernate.dialect">org.hibernate.dialect.OracleDialect</prop>
            <prop key="hibernate.show_sql">true</prop>
            <prop key="hibernate.current_session_context_class">org.springframework.orm.hibernate4.SpringSessionContext
            </prop>
        </props>
    </property>
</bean>

誰かが助けてくれることを願っています。おそらく私のコードから明らかなように、私は春にとても慣れていません。

4

1 に答える 1

1

AbstractTransactionalJUnit4SpringContextTestsテスト後にロールバックします。最後の行にブレークポイントを設定してから、データベースを調べてみてください。Rollbackこのデフォルトの動作が必要ない場合は、注釈を使用できます。

于 2012-10-06T10:14:59.507 に答える