NotWritablePropertyException: свойство bean-компонента "dataSource" недоступно для записи или имеет недопустимый метод установки
Я реализую Spring Transaction на своем уровне обслуживания приложений.
Я имел в виду пример учебника для программного способа реализации весенней транзакции...
https://www.tutorialspoint.com/spring/programmatic_management.htm
Я следовал за каждым & каждым шагом, упомянутым там.... но получая проблему с созданием бина в файле XML..
Ошибка:
Исключение в потоке "main" org.springframework.beans.factory.BeanCreationException: Ошибка при создании bean-компонента с именем'actionManager ', определенным в ресурсе пути к классу [database / spring.xml]: Ошибка при установке значений свойств; вложенным исключением является org.springframework.beans.NotWritablePropertyException: недопустимое свойство 'dataSource' класса бина [org.springframework.jdbc.datasource.DataSourceTransactionManager]: свойство бина 'dataSource' не доступно для записи или имеет недопустимый метод установки. Соответствует ли тип параметра установщика возвращаемому типу получателя?
Конфигурация системы и приложения: ОС: Ubuntu 16.0.4, весенняя версия: - 5.0.3. tomcat: 9 jdk: 1.9
IDE: Eclipse Oxygen 3
Для меня будет очень полезно, если кто-нибудь может дать мне решение...
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-2.5.xsd">
<!-- ********************* Initialization for Inventory database -->
<bean id="dataSource"
class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName" value="com.mysql.jdbc.Driver" />
<property name="url" value="jdbc:mysql://localhost:3306/myDatabase" />
<property name="username" value="root" />
<property name="password" value="root" />
</bean>
<!--********************* Initialization for TransactionManager -->
<bean class="org.springframework.jdbc.datasource.DataSourceTransactionManager" id="transactionManager">
<property name="dataSource" ref="dataSource"></property>
</bean>
</beans>
public class MyService implements InventoryServiceIface{
private MyDAO dao;
private PlatformTransactionManager transactionManager;
public void setTransactionManager(PlatformTransactionManager transactionManager) {
this.transactionManager = transactionManager;
}
public void setDAO(MyDAO dao) {
this.dao = dao;
}
public Student saveStudent(Student tudent) throws ServiceException{
validate(Student); // validate the data inside party object
TransactionStatus status = beginTransaction(); // begin database transaction
try
{
rollbackTransaction();
Student = dao.saveStudent(student);
}
catch(ServiceException e)
{
rollbackTransaction(status);
throw e;
}
catch(Exception e)
{
rollbackTransaction(status);
throw new ServiceException(e);
}
commitTransaction(status);
return student;
}
public TransactionStatus beginTransaction()
{
System.out.println("TRANSACTION BEGINS....");
return transactionManager.getTransaction(new DefaultTransactionDefinition());
}
public void rollbackTransaction(TransactionStatus status)
{
System.out.println("ROLL BACK....");
transactionManager.rollback(status);
}
public void commitTransaction(TransactionStatus status)
{
System.out.println("TRANSACTION COMMITTED....");
transactionManager.commit(status);
}
}// End of Class
1 ответ
Имя свойства DataSourceTransactionManager, которое задает источник данных, записано в стековой трассировке dataSource, а не xxxxxDataSource . ваш конфиг должен быть следующим
<bean class="org.springframework.jdbc.datasource.
DataSourceTransactionManager" id="transactionManager">
<property name="dataSource" ref="xxxxDataSource">
</property>
</bean>