Grundlegendes zum Überschreiben von Spaltenanmerkungen in Spring Boot JPA
Spring Boot JPA, ein beliebtes ORM-Framework, ermöglicht Entwicklern das Annotieren von Entitäten mit @Column Geben Sie bestimmte Spaltennamen in der Datenbank an. Es wurde jedoch beobachtet, dass JPA in bestimmten Szenarien möglicherweise die @Column-Annotation ignoriert und standardmäßig die mit Unterstrichen versehene Version des Eigenschaftsnamens im Datenbankschema verwendet.
Warum JPA die Spaltenanmerkung ignorieren kann
Ein möglicher Grund dafür, dass JPA die @Column-Annotation ignoriert, könnte die vom zugrunde liegenden Hibernate-Framework verwendete Benennungsstrategie sein. Standardmäßig verwendet Hibernate die Strategie org.hibernate.cfg.ImprovedNamingStrategy, die unabhängig von der @Column-Annotation Snake Case-Spaltennamen generiert.
Lösung: EJB3-Benennungsstrategie
Um dieses Problem zu beheben und sicherzustellen, dass JPA die @Column-Annotation berücksichtigt, können Sie die Hibernate-Benennungsstrategie explizit auf org.hibernate.cfg.EJB3NamingStrategy festlegen. Bei dieser Strategie bleiben die in der @Column-Annotation angegebenen Groß- und Kleinschreibung und der Zeichenabstand erhalten.
Überlegungen zum SQL Server-Dialekt
Wenn Sie eine Verbindung zu Microsoft SQL Server herstellen, kann Folgendes auftreten ein anderes Problem, bei dem Hibernate den Dialekt org.hibernate.dialect.SQLServerDialect verwendet. Dieser Dialekt kann zu Namensinkonsistenzen führen, bei denen JPA möglicherweise Spaltennamen mit gemischter Groß-/Kleinschreibung verwendet, selbst mit der EJB3-Namensstrategie.
Alte implizite und physische Namensstrategien
Ansprechen Um dieses Problem zu lösen, können Sie die folgenden Eigenschaften zu Ihrer application.properties-Datei hinzufügen:
spring.jpa.hibernate.naming.implicit-strategy=org.hibernate.boot.model.naming.ImplicitNamingStrategyLegacyJpaImpl
spring.jpa.hibernate.naming.physical-strategy=org.hibernate.boot.model.naming.PhysicalNamingStrategyStandardImpl
Diese Einstellungen zwingen Hibernate dazu, die Legacy Implicit- und Standard Physical-Benennungsstrategien zu verwenden, wodurch sichergestellt wird, dass die Die @Column-Annotation wird berücksichtigt und Spaltennamen werden konsistent generiert.
Haftungsausschluss: Alle bereitgestellten Ressourcen stammen teilweise aus dem Internet. Wenn eine Verletzung Ihres Urheberrechts oder anderer Rechte und Interessen vorliegt, erläutern Sie bitte die detaillierten Gründe und legen Sie einen Nachweis des Urheberrechts oder Ihrer Rechte und Interessen vor und senden Sie ihn dann an die E-Mail-Adresse: [email protected] Wir werden die Angelegenheit so schnell wie möglich für Sie erledigen.
Copyright© 2022 湘ICP备2022001581号-3