Maison > base de données > tutoriel mysql > Pourquoi le chargement paresseux de blob échoue-t-il dans mon application Spring/Hibernate ?

Pourquoi le chargement paresseux de blob échoue-t-il dans mon application Spring/Hibernate ?

Patricia Arquette
Libérer: 2024-11-03 03:09:29
original
985 Les gens l'ont consulté

Why is Lazy Blob Loading Failing in My Spring/Hibernate Application?

Chargement paresseux de blob au printemps, mise en veille prolongée

Dans le contexte de votre application Web, vous êtes confronté à un problème de chargement paresseux de blob dans Hiberner. Pour clarifier votre problème, les enregistrements de base de données que vous essayez d'afficher sur la page Web sont des fichiers volumineux stockés dans MySQL.

La configuration de votre base de données implique MySQL, Tomcat, Spring et Hibernate. Vous avez défini un champ blob paresseux dans votre classe d'entité à l'aide des annotations @Lob, @Basic(fetch=FetchType.LAZY) et @Column.

Cependant, malgré le marquage du champ blob comme paresseux, vous êtes rencontrer une OutOfMemoryError lorsque le volume de données est important. Vous avez également essayé de définir des valeurs nulles dans le champ blob pour chaque ligne, ce qui résout le problème de mémoire, vous laissant croire que le comportement de chargement paresseux ne fonctionne pas comme prévu.

La source de confusion réside dans les informations contradictoires disponibles en ligne. Alors que certaines sources indiquent que les champs @Lob sont intrinsèquement paresseux, d'autres suggèrent que le chargement différé peut ne pas fonctionner de manière cohérente sur tous les pilotes et bases de données.

Solutions potentielles :

  • Utilisez de « faux » mappages un-à-un : Comme suggéré dans la documentation, vous pouvez créer des classes distinctes pour les champs LOB et les mapper en tête-à-tête avec fetch="select" et lazy="true" vers votre entité principale. Cette approche garantit que les champs LOB ne sont chargés que lorsqu'ils sont explicitement demandés.
  • Essayez l'instrumentation de bytecode : Certains utilisateurs ont signalé du succès avec des bibliothèques d'instrumentation de bytecode comme Javaassist ou Cglib pour un chargement paresseux de blob. .
  • Consultez la documentation et les forums : Effectuez une recherche approfondie dans la documentation Hibernate et Spring, ainsi que ainsi que des forums en ligne, pour plus d'informations et des solutions potentielles à votre situation spécifique.

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!

source:php.cn
Déclaration de ce site Web
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal