Maison >Java >javaDidacticiel >La différence entre Mybatis et Mybatis Plus

La différence entre Mybatis et Mybatis Plus

Guanhui
Guanhuioriginal
2020-06-03 12:02:548753parcourir

La différence entre Mybatis et Mybatis Plus

La différence entre Mybatis et Mybatis Plus

Mybatis-Plus est un outil amélioré pour Mybatis. Il n'est amélioré que sur la base de Mybatis. . Sans modifications, MyBatis-Plus prend en charge toutes les fonctionnalités natives de Mybatis, donc l'introduction de Mybatis-Plus n'aura aucun impact sur l'architecture Mybatis existante.


Avantages MyBatis-Plus

Peu de dépendances : comptez uniquement sur Mybatis et Mybatis-Printemps.

2. Faible perte : le CURD de base sera automatiquement injecté au démarrage, avec pratiquement aucune perte de performances et un fonctionnement directement orienté objet.

3. Empêcher l'injection SQL : le décapant d'injection SQL intégré peut empêcher efficacement les attaques par injection SQL.

4. Opérations CRUD universelles : mappeur universel intégré et service universel, la plupart des opérations CRUD sur une seule table peuvent être réalisées avec seulement une petite quantité de configuration, et il existe également de puissants constructeurs conditionnels pour répondre à diverses utilisations. besoins.

5. Plusieurs stratégies de clé primaire : prend en charge jusqu'à 4 stratégies de clé primaire (y compris un générateur d'ID unique distribué), qui peuvent être librement configurées pour résoudre parfaitement le problème de clé primaire.

6. Prise en charge du chargement à chaud : le XML correspondant à Mapper prend en charge le chargement à chaud. Pour les opérations CRUD simples, il peut même être démarré sans XML

7. classe uniquement Vous devez hériter de la classe Model pour implémenter les opérations CRUD de base

8. Prise en charge de la génération de code : utilisez du code ou des plug-ins Maven pour générer rapidement des codes de couche Mapper, Model, Service et Controller (générer des fichiers personnalisés pour éviter de développer du code en double), prend en charge les moteurs de modèles, possède de nombreuses configurations personnalisées, etc.

9. Prise en charge des opérations universelles globales personnalisées : prise en charge de l'injection de méthode universelle globale (écrire une fois, utiliser n'importe où).

10. Prend en charge l'échappement automatique des mots-clés : prend en charge l'échappement automatique des mots-clés de la base de données (ordre, clé...), et peut également personnaliser les mots-clés.

11. Plug-in de pagination intégré : basé sur la pagination physique Mybatis, les développeurs n'ont pas besoin de se soucier d'opérations spécifiques. Après avoir configuré le plug-in, l'écriture de la pagination est équivalente à une requête de liste ordinaire.

12. Plug-in d'analyse des performances intégré : il peut générer des instructions SQL et leur temps d'exécution. Il est recommandé d'activer cette fonction pendant le développement et les tests, ce qui peut résoudre efficacement les requêtes lentes.

13. Plug-in d'interception globale intégré : fournit une analyse intelligente et un blocage des opérations de suppression et de mise à jour dans l'ensemble de la table pour éviter les erreurs d'opération.

14. Par défaut, le nom de classe de la classe d'entité est recherché pour la table dans la base de données. Utilisez l'annotation @TableName(value="table1") pour spécifier le nom de la table et @TableId pour spécifier. la clé primaire de la table Si le champ est cohérent avec le nom du champ dans la table Aucune annotation n'est requise s'il est cohérent.

Tutoriel recommandé : "Tutoriel Java"

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn