2012-12-11 203 views
1

我是新來的春天,所以如果一切都配置正確,我不知道。儘管我使用了Spring IDE,並提供了單元測試是正確的。春天JPA HSQLDB持久

我有一個User類

@Entity 
@NamedQuery(name="findUser4Email", 
query="SELECT * " + 
     "FROM User " + 
     "WHERE email = :userEmail") 
public class User extends AbstractNamedDomain { 

private String name; 
private String email; 
private String password; 
... 

我想保持這種類持久性與DB。我使用hsqldb發送查詢到我的數據庫等。

現在,我有我的用戶使用DAO層,看起來像這樣:

public class UserManager implements IUserManager { 

    @PersistenceContext 
    private EntityManager em; 

public User findUser4Email(String email) { 
    return (User) em.createNamedQuery("findUser4Email").setParameter("userEmail", 
      email).getSingleResult(); 
} 

public User storeUser(User user) { 
    //User u = em.merge(user); 
    em.persist(user); 
    return user; 
} 
... 

我的豆子看起來像這樣:

<?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:aop="http://www.springframework.org/schema/aop" 
    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.5.xsd 
    http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd 
    http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd"> 

    <bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean"> 
      <property name="dataSource" ref="dataSource" /> 
      <property name="persistenceUnitName" value="BankingWeb" /> 
      <property name="jpaVendorAdapter"> 
        <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter"> 
          <property name="generateDdl" value="true" /> 
          <property name="showSql" value="true" /> 
          <property name="databasePlatform" value="${hibernate.dialect}" /> 
        </bean> 
      </property> 
    </bean> 

    <bean class="org.springframework.orm.jpa.support.PersistenceAnnotationBeanPostProcessor" /> 

    <bean name="AccountManager" class="ssel.banking.dao.jpa.AccountManager" /> 

    <bean name="UserManager" class="ssel.banking.dao.jpa.UserManager" /> 


    <bean id="txManager" class="org.springframework.orm.jpa.JpaTransactionManager"> 
      <property name="entityManagerFactory" ref="entityManagerFactory" /> 
    </bean> 

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

    </beans> 

當我嘗試存儲用戶在單元測試中(僅僅通過調用dao中的store(User)來測試失敗)當我用hsqldb查看時,我也沒有看到在我的數據庫中創建了任何表。我想念我的帽子?

這是我datasourcebean是什麼樣子

 <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"> 
    <property name="url" value="${jdbc.url}"/> 
    <property name="driverClassName" value="${jdbc.driverClassName}"/> 
    <property name="username" value="${jdbc.username}"/> 
    <property name="password" value="${jdbc.password}"/> 
</bean> 
+0

您可以發佈啓動單元測試時得到的錯誤嗎?你的項目中是否有其他配置文件(如persistence.xml)? –

+0

我沒有錯誤,它似乎沒有東西插入分貝 –

+0

好吧,你可以添加你的dataSource bean的定義。 Thx –

回答

1

你必須定義一個DataSource的bean是這樣的:

<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> 
    <property name="driverClassName" value="com.mysql.jdbc.Driver"/> 
    <property name="url" value="jdbc:mysql://192.0.0.1:3306/yourDB"/> 
    <property name="username" value=""/> 
    <property name="password" value=""/> 
</bean> 

(或者JNDI查找)

<jee:jndi-lookup jndi-name="jdbc/datasource" id="dataSource" /> 

你可以按照這tutorial來幫助你設置一切。

+1

爲什麼如果問題是關於你回答MySQL的HSQLDB? – Betlista