Maison  >  Article  >  Java  >  ## SELECT NEW dans JPQL : outil électrique ou piège potentiel ?

## SELECT NEW dans JPQL : outil électrique ou piège potentiel ?

Linda Hamilton
Linda Hamiltonoriginal
2024-10-25 10:18:31955parcourir

## SELECT NEW in JPQL: Power Tool or Potential Pitfall?

Le pouvoir ou le péril de JPQL : utiliser SELECT NEW pour créer des objets

Le domaine du langage de requête de persistance Java (JPQL) offre une fonctionnalité puissante connue comme SELECT NEW, permettant la création de nouveaux objets dans une instruction select. Au lieu de récupérer les instances gérées par le contexte de persistance, cette construction facilite la manipulation des objets transitoires. Cependant, la question demeure : SELECT NEW est-il un outil à adopter ou à éviter ?

Etreintes justifiées

Selon la spécification JPA EJB 3.0, SELECT NEW sert des objectifs spécifiques :

  • Renvoie les instances Java personnalisées, y compris les classes non mappées.
  • Récupération sécurisée de propriétés spécifiques à partir d'entités jointes.

Un exemple serait être une requête récupérant les détails du client sans l'entité client complète :

SELECT NEW com.acme.example.CustomerDetails(c.id, c.status, o.count)
FROM Customer c JOIN c.orders o
WHERE o.count > 100

Quand éviter

Bien que SELECT NEW offre des commodités, il ne doit pas être utilisé sans discernement. Son utilisation prudente est limitée aux scénarios dans lesquels :

  • Éviter la récupération complète de l'entité pour améliorer les performances ou des cas d'utilisation spécifiques.
  • Récupérer des propriétés d'entités qui ne sont pas entièrement jointes ou mappées.

Adopter les bonnes pratiques

Loin de décourager l'utilisation de SELECT NEW, il est crucial de l'adopter tout en adhérant aux bonnes pratiques :

  • Évitez de l'utiliser comme substitut à des jointures correctement conçues.
  • Considérez les implications potentielles en termes de performances lors de la création de grandes collections d'objets non gérés.
  • Limitez son utilisation aux cas où il améliore l'expressivité ou l'efficacité du requête.

Conclusion

SELECT NEW est un outil précieux lorsqu'il est appliqué de manière appropriée. En profitant de ses avantages tout en adhérant aux meilleures pratiques, les développeurs peuvent tirer parti de la puissance de JPQL tout en évitant les pièges. Que SELECT NEW doive être adopté ou évité est donc une question d’application judicieuse, reconnaissant son utilité dans des contextes spécifiques sans succomber à une confiance excessive.

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