Maison >Java >javaDidacticiel >Comment gérer les mots-clés réservés dans le mappage des champs d'entité JPA ?

Comment gérer les mots-clés réservés dans le mappage des champs d'entité JPA ?

Susan Sarandon
Susan Sarandonoriginal
2024-12-02 04:23:15695parcourir

How to Handle Reserved Keywords in JPA Entity Field Mapping?

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

Lors du mappage de champs d'entité dont les noms sont des mots réservés dans JPA, tels que « ouvrir » dans SQL Server, des problèmes peuvent survenir . Hibernate utilise généralement des identifiants entre guillemets lors de la création de tables, garantissant que les mots-clés réservés n'interfèrent pas avec les requêtes SQL. Cependant, cela ne se produit pas toujours, ce qui entraîne des erreurs comme celle rencontrée dans l'exemple.

Échapper aux mots-clés réservés avec des backticks (JPA 1.0)

Dans JPA 1.0, le problème peut être résolu en en utilisant des backticks autour du mot-clé réservé dans l'annotation @Column :

@Column(name="`open`")

Hibernate encadrera alors le identifiant entre guillemets appropriés basés sur le dialecte SQL.

Utilisation de guillemets doubles (JPA 2.0)

Dans JPA 2.0, la syntaxe d'échappement des mots-clés réservés a été standardisée, à l'aide de guillemets doubles :

@Column(name="\"open\"")

Cette approche ajoutera automatiquement les guillemets nécessaires au SQL requêtes.

Documentation de référence

  • [Guide de référence Hibernate](https://docs.jboss.org/hibernate/stable/)
  • [Identifiants cités SQL en veille prolongée Noyau](https://docs.jboss.org/hibernate/orm/5.6/userguide/html_single/Hibernate_User_Guide.html#identifiers-delimit-identifiers)
  • [JPA 2.0 Spécification](https://docs.oracle.com/javaee/7/api/javax/persistence/package-summary.html)
  • [Nom des objets de base de données dans JPA 2.0](https://docs .oracle.com/javaee/7/api/javax/persistence/Table.html#name--))

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