Maison > Java > javaDidacticiel > Comment puis-je mapper les champs d'entité JPA avec des mots-clés réservés ?

Comment puis-je mapper les champs d'entité JPA avec des mots-clés réservés ?

Linda Hamilton
Libérer: 2024-12-02 22:32:11
original
323 Les gens l'ont consulté

How Can I Map JPA Entity Fields with Reserved Keywords?

Mappage des champs d'entité avec des mots-clés réservés dans JPA

L'incapacité de mapper directement les champs d'entité dont les noms sont des mots-clés réservés dans JPA peut présenter des obstacles au développement d'applications, en particulier lorsque vous travaillez avec des dialectes qui appliquent strictement les règles de syntaxe. Cependant, il existe une solution simple disponible dans Hibernate en tant que fournisseur JPA.

Utilisation de l'échappement d'identifiant avec des backticks

Pour échapper aux mots-clés réservés, placez-les entre des backticks dans le @ Annotation de colonne. Cette fonctionnalité est héritée d'Hibernate Core et prend en charge le style de citation correct basé sur le dialecte SQL. Pour SQL Server, cela se traduit par l'utilisation de crochets pour les guillemets.

Dans Hibernate en tant que fournisseur JPA 1.0 :

@Column(name="`open`")
Copier après la connexion

Dans JPA 2.0 :

@Column(name="\"open\"")
Copier après la connexion

En utilisant ceci approche, Hibernate garantit que le mot clé réservé est correctement cité lors de la création de la table, évitant ainsi des problèmes comme celui rencontré avec l'option 'open'. champ.

Ressources supplémentaires

  • [Guide de référence Hibernate](https://docs.jboss.org/hibernate/orm/6.0/userguide/html_single /)
  • [5.4. Identifiants SQL cités](https://docs.jboss.org/hibernate/orm/6.0/userguide/html/identifiers.html#naming-sql-quoted-identifiers)
  • [Spécification JPA 2.0](https ://jcp.org/en/jsr/detail?id=338)
  • [2.13 Dénomination de la base de données Objets](https://docs.oracle.com/javaee/7/api/javax/persistence/metamodel/Attribute.html#getName--)

Questions connexes

  • [Hibernate, MySQL et table nommée « Répéter » - étrange behavior](https://stackoverflow.com/questions/56279222/hibernate-mysql-and-table-named-repeat-strange-behaviour)
  • [Échappement automatique des mots réservés pour les tables Hibernate et colonnes](https://stackoverflow.com/questions/24237940/automatic-reserved-word-escaping-for-hibernate-tables-and-columns)

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