Questions d'entretien sur la couche de persistance Java (1)
Mar 14, 2020 pm 05:45 PM1. Qu'est-ce que l'ORM??
Le mappage objet-relationnel (ORM) est une technologie permettant de résoudre le problème d'inadéquation entre le modèle orienté objet du programme et le modèle relationnel de la base de données
Simple In?; en d'autres termes, ORM conserve automatiquement les objets du programme dans la base de données relationnelle ou convertit les lignes de la table de la base de données relationnelle en utilisant des métadonnées qui décrivent le mappage entre l'objet et la base de données (XML ou annotations peuvent être utilisées en Java). Objet Java, qui convertit essentiellement les données d'un formulaire à un autre.
2. SessionFactory dans Hibernate est-il thread-safe?? La session est-elle thread-safe (deux threads peuvent-ils partager la même session)??
SessionFactory correspond à un concept de stockage de données d'Hibernate. Il est thread-safe et est accessible simultanément par plusieurs threads. SessionFactory n'est généralement construit qu'au démarrage. Pour les applications, il est préférable d'encapsuler SessionFactory via le mode singleton pour un accès facile.
(Recommandation vidéo d'apprentissage?: tutoriel vidéo Java)
La session est un objet léger non thread-safe (la session ne peut pas être partagée entre les threads), qui représente la connexion avec la base de données Une unité de travail avec laquelle interagit. La session est créée par SessionFactory et elle sera fermée une fois la tache terminée. La session est l'interface principale fournie par le service de couche de persistance.
La session retardera l'obtention de la connexion à la base de données (c'est-à-dire qu'elle ne l'obtiendra qu'en cas de besoin). Afin d'éviter de créer trop de sessions, vous pouvez utiliser ThreadLocal pour lier la session au thread actuel, afin que le même thread obtienne toujours la même session. La méthode getCurrentSession() de SessionFactory dans Hibernate 3 peut le faire.
3. Que font les méthodes save(), update(), merge(), lock(), saveOrUpdate() et persist() de Session?? Quelle est la différence ?
Les objets Hibernate ont trois états?: transitoire, persistant et détaché.
Les instances transitoires peuvent être rendues persistantes en appelant save(), persist() ou saveOrUpdate();
Les instances gratuites peuvent être rendues persistantes en appelant update(), saveOrUpdate(), lock( ) ou replicate() devient persistant. save() et persist() déclencheront des instructions SQL INSERT, et update() ou merge() déclencheront des instructions UPDATE.
La différence entre save() et update() est que l'un transforme un objet transitoire en un état persistant et l'autre transforme un objet libre en un état persistant. La méthode merge() peut compléter les fonctions des méthodes save() et update(). Son intention est de fusionner le nouvel état dans l'objet persistant existant ou de créer un nouvel objet persistant.
Pour la méthode persist(), suivez les instructions de la documentation officielle?:
1. La méthode persist() persiste une instance transitoire, mais elle ne garantit pas que l'identifiant sera rempli. dans immédiatement. Dans une instance persistante, le remplissage de l'identifiant peut être reporté jusqu'au moment du vidage
2. La méthode persist() garantit que lorsqu'elle est appelée en dehors d'une transaction, elle ne déclenchera pas d'instruction INSERT ; . Si nécessaire Lors de l'encapsulation d'un long processus de session, la méthode persist() est nécessaire
(Tutoriel recommandé?: Java Quick Start)
3. L'élément 2 n'est pas garanti, il renvoie l'identifiant, il exécutera donc l'instruction INSERT immédiatement, que ce soit à l'intérieur ou à l'extérieur de la transaction. Quant à la différence entre la méthode lock() et la méthode update(), la méthode update() change un objet dans un état détaché qui a été transformé en un état persistant, la méthode lock() change un objet dans un état détaché?; cela n’est pas devenu un état persistant.
4. Expliquez le processus de chargement des objets d'entité dans la session
1 Avant d'appeler la fonction de requête de base de données, la session utilisera d'abord le type d'entité et la clé primaire dans le. recherche dans le cache de premier niveau, si la recherche dans le cache de premier niveau réussit et que l'état des données est légal, retournez directement
2. Si le cache de premier niveau n'aboutit pas, alors la session sera enregistrée dans ; les NonExists actuels (équivalent à une liste noire de requêtes, si les requêtes invalides répétées peuvent être rapidement jugées, améliorant ainsi les performances). Si la même condition de requête existe dans NonExists, null sera renvoyé
Si le premier-?; la requête du cache de niveau échoue, interrogez le cache de deuxième niveau, si le cache de deuxième niveau atteint, il sera renvoyé directement
4. Si les requêtes précédentes n'ont pas abouti, l'instruction SQL sera émise. la requête ne trouve pas l'enregistrement correspondant, la requête sera ajoutée aux NonExists de la session pour l'enregistrer, et renvoie null
5 Obtenez le ResultSet selon la configuration du mappage et l'instruction SQL, et créez. l'objet entité correspondant?;
6. Incorporer l'objet dans la gestion de la session (cache de niveau un)?;
7. S'il existe un intercepteur correspondant, exécutez la méthode onLoad de l'intercepteur?;
8. S'il est activé et configuré pour utiliser le cache de deuxième niveau, l'objet de données sera inclus dans le cache de deuxième niveau
9.
5. Quelle est la différence entre utiliser # et $ pour écrire des espaces réservés dans MyBatis??
# Traitez les données entrantes comme une cha?ne et ajoutez automatiquement des guillemets aux données entrantes
$ affiche et génère les données entrantes directement en SQL.
Remarque?: l'utilisation de l'espace réservé $ peut conduire à des attaques par injection SQL. N'utilisez pas $ où # peut être utilisé. Vous devez utiliser $ au lieu de # lors de l'écriture de la clause order by.
Recommandations de tutoriel associées?: questions d'entretien 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!

Outils d'IA chauds

Undress AI Tool
Images de déshabillage gratuites

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
échangez les visages dans n'importe quelle vidéo sans effort grace à notre outil d'échange de visage AI entièrement gratuit?!

Article chaud

Outils chauds

Bloc-notes++7.3.1
éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Pour gérer correctement les transactions JDBC, vous devez d'abord désactiver le mode de validation automatique, puis effectuer plusieurs opérations, et enfin vous engager ou randonner en fonction des résultats; 1. Appelez Conn.SetAutoCommit (false) pour démarrer la transaction; 2. Exécuter plusieurs opérations SQL, telles que l'insertion et la mise à jour; 3. Appelez Conn.Commit () Si toutes les opérations sont réussies, et appelez Conn.Rollback () Si une exception se produit pour garantir la cohérence des données; Dans le même temps, les ressources TRY-With doivent être utilisées pour gérer les ressources, gérer correctement les exceptions et cl?turer les connexions pour éviter la fuite de connexion; De plus, il est recommandé d'utiliser des pools de connexion et de définir des points de sauvegarde pour réaliser un retour en arrière partiel, et de maintenir les transactions aussi courtes que possible pour améliorer les performances.

Pré-formancetartuptimemoryusage, quarkusandmicronautleadduetocompile-timeprocessingandgraalvsupport, withquarkusofperforming lightbetterine scénarios.

HTTP Log Middleware dans GO peut enregistrer les méthodes de demande, les chemins de requête, la propriété intellectuelle du client et le temps qui prend du temps. 1. Utilisez http.handlerfunc pour envelopper le processeur, 2. Enregistrez l'heure de début et l'heure de fin avant et après l'appel Suivant.Servehttp, 3. Obtenez le vrai client IP via R.RemoteAddr et X-Forwared-For Headers, 4. Utilisez le log.printf aux journaux de demande de sortie, 5. L'exemple de code complet a été vérifié pour s'exécuter et convient au démarrage d'un projet petit et moyen. Les suggestions d'extension incluent la capture des codes d'état, la prise en charge des journaux JSON et le suivi des ID de demande.

La collecte des ordures de Java (GC) est un mécanisme qui gère automatiquement la mémoire, ce qui réduit le risque de fuite de mémoire en récupérant des objets inaccessibles. 1. GC juge l'accessibilité de l'objet de l'objet racine (tel que les variables de pile, les threads actifs, les champs statiques, etc.), et les objets inaccessibles sont marqués comme des ordures. 2. Sur la base de l'algorithme de compensation de marque, marquez tous les objets accessibles et effacez des objets non marqués. 3. Adopter une stratégie de collecte générationnelle: la nouvelle génération (Eden, S0, S1) exécute fréquemment MinorGC; Les personnes agées fonctionnent moins, mais prend plus de temps pour effectuer MajorGC; Metaspace Stores Metadata de classe. 4. JVM fournit une variété de périphériques GC: SerialGC convient aux petites applications; Le parallelGC améliore le débit; CMS réduit

Le choix du bon type HTMLinput peut améliorer la précision des données, améliorer l'expérience utilisateur et améliorer la convivialité. 1. Sélectionnez les types d'entrée correspondants en fonction du type de données, tels que le texte, le courrier électronique, le tel, le numéro et la date, qui peuvent vérifier automatiquement la somme de la somme et l'adaptation au clavier; 2. Utilisez HTML5 pour ajouter de nouveaux types tels que l'URL, la couleur, la plage et la recherche, qui peuvent fournir une méthode d'interaction plus intuitive; 3. Utilisez l'espace réservé et les attributs requis pour améliorer l'efficacité et la précision du remplissage des formulaires, mais il convient de noter que l'espace réservé ne peut pas remplacer l'étiquette.

GradleisthebetterChoiceFormostNewProjectsDuetOtsSuperiorflexibility, Performance et ModerNtoolingSupport.1.gradle’sgroovy / kotlindslismoreConcis

La réponse claire à cette question est la recommandation d'implémenter le modèle d'observateur à l'aide d'une interface d'observateur personnalisée. 1. Bien que Java offre observable et observateur, le premier est une classe et a été obsolète et manque de flexibilité; 2. La pratique recommandée moderne consiste à définir une interface d'observateur fonctionnel, et le sujet maintient la liste des observateurs et informe tous les observateurs lorsque l'état change; 3. Il peut être utilisé en combinaison avec les expressions de lambda pour améliorer la simplicité et la maintenabilité du code; 4. Pour les scénarios GUI ou Javabean, PropertyChangeListener peut être utilisé. Par conséquent, les nouveaux projets devraient adopter un schéma d'interface d'observateur personnalisé, qui est sécurisé, facile à tester et se spécialise dans le Java moderne

L'utilisation de la bibliothèque OpenCSV est le meilleur choix pour lire les fichiers CSV. Il peut gérer des situations complexes et prend en charge plusieurs fonctionnalités; 2. Pour les fichiers CSV simples, vous pouvez utiliser BufferedReader intégré de Java combiné avec la méthode Split; 3. Si vous avez besoin d'un contr?le de format plus flexible ou si vous avez utilisé des composants Apache, vous pouvez choisir Apache Commonscsv. OpenCSV est recommandé pour sa simplicité, sa robustesse et sa capacité à gérer les problèmes de CSV dans des scénarios réels.
