我尝试使用Springboot和JPA来使用多个数据源,但在尝试启动服务器时遇到错误。
只有在我尝试使用第二个数据源时才会出现此问题。尝试启动我的应用程序时出现以下错误:
Not an managed type: class com.company.app.backoffice.modelDocument.Category
一切都适用于第一个数据源。但似乎我的第二个实体经理没有追踪好的包裹。例如,我需要我的第一个数据源来管理我的模型包,而我需要第二个管理modelDocument包:
<!-- Configure the data source bean -->
<!-- Website datasource -->
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
<property name="driverClassName" value="${jdbc.driverClassName}"/>
<property name="url" value="${jdbc.url}"/>
<property name="username" value="${jdbc.username}"/>
<property name="password" value="${jdbc.password}"/>
</bean>
<!-- Doc base datasource -->
<bean id="docDataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
<property name="driverClassName" value="${jdbc.driverClassName}"/>
<property name="url" value="${jdbc.doc.url}"/>
<property name="username" value="${jdbc.doc.username}"/>
<property name="password" value="${jdbc.doc.password}"/>
</bean>
<!-- Configure the entity manager factory bean -->
<!-- Website Entity manager -->
<bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
<property name="dataSource" ref="dataSource"/>
<property name="packagesToScan" value="com.company.app.backoffice.model"/>
<property name="jpaVendorAdapter">
<bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter"/>
</property>
<property name="jpaProperties">
<props>
<prop key="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</prop>
<prop key="hibernate.show_sql">true</prop>
</props>
</property>
</bean>
<!-- Doc base Entity manager -->
<bean id="docEntityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
<property name="dataSource" ref="docDataSource"/>
<property name="packagesToScan" value="com.company.app.backoffice.modelDocument"/>
<property name="jpaVendorAdapter">
<bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter"/>
</property>
<property name="jpaProperties">
<props>
<prop key="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</prop>
<prop key="hibernate.show_sql">true</prop>
</props>
</property>
</bean>
<!-- Configure the transaction manager bean -->
<!-- Website transation manager -->
<bean id="transactionManager"
class="org.springframework.orm.jpa.JpaTransactionManager">
<property name="entityManagerFactory" ref="entityManagerFactory"/>
</bean>
<!-- Doc base transaction manager -->
<bean id="docTransactionManager"
class="org.springframework.orm.jpa.JpaTransactionManager">
<property name="entityManagerFactory" ref="docEntityManagerFactory"/>
</bean>
这是我需要在第二个数据源中管理的类,它位于modelDocument包中:
@Entity
@Table(name = "category")
public class Category {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private Long id;
@Column
private String name;
public Long getId() {
return id;
}
public String getName() {
return name;
}
}
有人知道这有什么问题吗?
编辑:用于管理实体持久性的隐式存储库
package com.company.app.backoffice.repository;
import com.company.app.backoffice.modelDocument.Category;
import org.springframework.data.jpa.repository.JpaRepository;
public interface CategoryRepository extends JpaRepository<Category, Long> {
}
编辑2:注入存储库的控制器:
@Controller
public class CategoryController {
@Autowired
private CategoryRepository categoryRepository;
@RequestMapping(value = "/categories", method = RequestMethod.GET, produces = "application/json")
@ResponseBody
public List<Category> categories() {
return categoryRepository.findAll();
}
}
答案 0 :(得分:2)
添加包含实体的包扫描
<jpa:repositories base-package="your.package.enties" />
答案 1 :(得分:0)
主要问题是您有两个不同的数据源和实体管理器来使用JPARepository。当你以这种方式工作时,我认为Spring会迷失方向。是仅使用一个datasource / em。我已经找到了一个解决方案,在Spring中将em / datasource设置为一个特定的JPARepository,我还没找到。尽管如此,您可以按照此tutorial创建自己的JPARepository实现并定义两个类。每个人都使用不同的数据源和EntityManager。这样做,你应该达到你想要的效果。
答案 2 :(得分:0)
如果您有多个数据源,则必须声明单独的事务管理器(PlatformTransactionManager
)和实体管理器(LocalContainerEntityManagerFactoryBean
)。所以Springboot感到困惑。要解决此问题,请使用@Primary
注释。将此批注放在任何一个事务管理器和任何一个实体管理器
干杯