Maison >Java >javaDidacticiel >Pourquoi les méthodes @Transactional échouent-elles lorsqu'elles sont auto-invoquées au sein de la même classe au printemps ?
Problème :
Au Spring, tenter d'invoquer une méthode annotée avec @Transaction au sein de la même classe peut entraîner une transaction inefficace.
Code Exemple :
public class UserService { @Transactional public boolean addUser(String userName, String password) { // ... } public boolean addUsers(List<User> users) { for (User user : users) { addUser(user.getUserName, user.getPassword); } } }
Comprendre le problème :
Ce problème survient en raison des limitations de la gestion dynamique des objets de Spring AOP et de l'utilisation de cglib. Le mécanisme de gestion des transactions par défaut de Spring utilise des proxys dynamiques créés avec cglib, ce qui peut provoquer des incohérences lors de l'appel d'une méthode transactionnelle à partir de la même classe.
Solution :
Utilisation d'AspectJ pour la gestion des transactions :
Pour résoudre ce problème, vous pouvez configurer Spring pour utiliser AspectJ pour gérer les transactions. Cela implique :
Définir le mode sur aspectj dans tx:annotation-driven :
<tx:annotation-driven mode="aspectj"/>
Ajout de la configuration du bean suivante (uniquement pour Versions de printemps ci-dessous 3.0) :
<bean class="org.springframework.transaction.aspectj.AnnotationTransactionAspect" factory-method="aspectOf"> <property name="transactionManager" ref="transactionManager"/> </bean>
Refactoring :
Une solution alternative consiste à refactoriser votre code. Au lieu d'invoquer la méthode transactionnelle à partir de la même classe, envisagez de créer des classes distinctes pour la gestion et le traitement des utilisateurs afin d'activer la gestion des transactions par défaut à l'aide de Spring AOP.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!