admin管理员组文章数量:1122846
I Have an SpringBoot 2.7.18 with H2 2.3.232, with this SQL for testing:
CREATE TABLE IF NOT EXISTS EXERCICE
(
EXERCICE_ID NUMBER AUTO_INCREMENT,
TYPE_SITE_ID NUMBER,
EXERCICE_META_ID NUMBER,
DESC_COURT VARCHAR(512),
DESC_LONG VARCHAR(2048),
DT_HORS_DELAI DATE,
DT_DEBUT DATE,
DT_FIN DATE,
DT_DEB_INSCRIPTION DATE,
DT_FIN_INSCRIPTION DATE,
DT_DEB_REINSCRIPTION DATE,
DT_FIN_REINSCRIPTION DATE,
DT_ANNULATION DATE,
COMMENTAIRE VARCHAR(2048),
KL_ID NUMBER,
CODE VARCHAR(64),
ORGANISATION_ID NUMBER
);
but when running the tests I have this error:
Caused by: javax.persistence.PersistenceException: Exception [EclipseLink-4002] (Eclipse Persistence Services - 2.7.15.v20240516-53511fdbd8): org.eclipse.persistence.exceptions.DatabaseException
Internal Exception: org.h2.jdbc.JdbcSQLSyntaxErrorException: Syntax error in SQL statement "CREATE TABLE IF NOT EXISTS EXERCICE\000d\000a(\000d\000a EXERCICE_ID NUMBER [*]AUTO_INCREMENT,\000d\000a TYPE_SITE_ID NUMBER,\000d\000a EXERCICE_META_ID NUMBER,\000d\000a DESC_COURT VARCHAR(512),\000d\000a DESC_LONG VARCHAR(2048),\000d\000a DT_HORS_DELAI DATE,\000d\000a DT_DEBUT DATE,\000d\000a DT_FIN DATE,\000d\000a DT_DEB_INSCRIPTION DATE,\000d\000a DT_FIN_INSCRIPTION DATE,\000d\000a DT_DEB_REINSCRIPTION DATE,\000d\000a DT_FIN_REINSCRIPTION DATE,\000d\000a DT_ANNULATION DATE,\000d\000a COMMENTAIRE VARCHAR(2048),\000d\000a KL_ID NUMBER,\000d\000a CODE VARCHAR(64),\000d\000a ORGANISATION_ID NUMBER\000d\000a)"; expected "(, ARRAY, INVISIBLE, VISIBLE, NOT NULL, DEFAULT, GENERATED, ON UPDATE, NOT NULL, DEFAULT ON NULL, SEQUENCE, SELECTIVITY, COMMENT, CONSTRAINT, COMMENT, PRIMARY KEY, UNIQUE, NOT NULL, CHECK, REFERENCES, ,, )"; SQL statement:
CREATE TABLE IF NOT EXISTS EXERCICE
(
EXERCICE_ID NUMBER AUTO_INCREMENT,
TYPE_SITE_ID NUMBER,
EXERCICE_META_ID NUMBER,
DESC_COURT VARCHAR(512),
DESC_LONG VARCHAR(2048),
DT_HORS_DELAI DATE,
DT_DEBUT DATE,
DT_FIN DATE,
DT_DEB_INSCRIPTION DATE,
DT_FIN_INSCRIPTION DATE,
DT_DEB_REINSCRIPTION DATE,
DT_FIN_REINSCRIPTION DATE,
DT_ANNULATION DATE,
COMMENTAIRE VARCHAR(2048),
KL_ID NUMBER,
CODE VARCHAR(64),
ORGANISATION_ID NUMBER
) [42001-232]
Error Code: 42001
at org.eclipse.persistence.internal.jpa.EntityManagerSetupImpl.deploy(EntityManagerSetupImpl.java:855)
at org.eclipse.persistence.internal.jpa.EntityManagerFactoryDelegate.getAbstractSession(EntityManagerFactoryDelegate.java:222)
at org.eclipse.persistence.internal.jpa.EntityManagerFactoryDelegate.getMetamodel(EntityManagerFactoryDelegate.java:679)
at org.eclipse.persistence.internal.jpa.EntityManagerFactoryImpl.getMetamodel(EntityManagerFactoryImpl.java:565)
at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.base/java.lang.reflect.Method.invoke(Method.java:566)
at org.springframework.orm.jpa.AbstractEntityManagerFactoryBean.invokeProxyMethod(AbstractEntityManagerFactoryBean.java:519)
at org.springframework.orm.jpa.AbstractEntityManagerFactoryBean$ManagedEntityManagerFactoryInvocationHandler.invoke(AbstractEntityManagerFactoryBean.java:734)
at com.sun.proxy.$Proxy32.getMetamodel(Unknown Source)
at java.base/java.util.stream.ReferencePipeline$3$1.accept(ReferencePipeline.java:195)
at java.base/java.util.Iterator.forEachRemaining(Iterator.java:133)
at java.base/java.util.Spliterators$IteratorSpliterator.forEachRemaining(Spliterators.java:1801)
at java.base/java.util.stream.AbstractPipeline.copyInto(AbstractPipeline.java:484)
at java.base/java.util.stream.AbstractPipeline.wrapAndCopyInto(AbstractPipeline.java:474)
at java.base/java.util.stream.ReduceOps$ReduceOp.evaluateSequential(ReduceOps.java:913)
at java.base/java.util.stream.AbstractPipeline.evaluate(AbstractPipeline.java:234)
at java.base/java.util.stream.ReferencePipeline.collect(ReferencePipeline.java:578)
at org.springframework.data.jpa.repository.config.JpaMetamodelMappingContextFactoryBean.getMetamodels(JpaMetamodelMappingContextFactoryBean.java:106)
at org.springframework.data.jpa.repository.config.JpaMetamodelMappingContextFactoryBean.createInstance(JpaMetamodelMappingContextFactoryBean.java:80)
at org.springframework.data.jpa.repository.config.JpaMetamodelMappingContextFactoryBean.createInstance(JpaMetamodelMappingContextFactoryBean.java:44)
at org.springframework.beans.factory.config.AbstractFactoryBean.afterPropertiesSet(AbstractFactoryBean.java:142)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1863)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1800)
... 67 common frames omitted
Caused by: org.eclipse.persistence.exceptions.DatabaseException:
Internal Exception: org.h2.jdbc.JdbcSQLSyntaxErrorException: Syntax error in SQL statement "CREATE TABLE IF NOT EXISTS EXERCICE\000d\000a(\000d\000a EXERCICE_ID NUMBER [*]AUTO_INCREMENT,\000d\000a TYPE_SITE_ID NUMBER,\000d\000a EXERCICE_META_ID NUMBER,\000d\000a DESC_COURT VARCHAR(512),\000d\000a DESC_LONG VARCHAR(2048),\000d\000a DT_HORS_DELAI DATE,\000d\000a DT_DEBUT DATE,\000d\000a DT_FIN DATE,\000d\000a DT_DEB_INSCRIPTION DATE,\000d\000a DT_FIN_INSCRIPTION DATE,\000d\000a DT_DEB_REINSCRIPTION DATE,\000d\000a DT_FIN_REINSCRIPTION DATE,\000d\000a DT_ANNULATION DATE,\000d\000a COMMENTAIRE VARCHAR(2048),\000d\000a KL_ID NUMBER,\000d\000a CODE VARCHAR(64),\000d\000a ORGANISATION_ID NUMBER\000d\000a)"; expected "(, ARRAY, INVISIBLE, VISIBLE, NOT NULL, DEFAULT, GENERATED, ON UPDATE, NOT NULL, DEFAULT ON NULL, SEQUENCE, SELECTIVITY, COMMENT, CONSTRAINT, COMMENT, PRIMARY KEY, UNIQUE, NOT NULL, CHECK, REFERENCES, ,, )"; SQL statement:
CREATE TABLE IF NOT EXISTS EXERCICE
(
EXERCICE_ID NUMBER AUTO_INCREMENT,
TYPE_SITE_ID NUMBER,
EXERCICE_META_ID NUMBER,
DESC_COURT VARCHAR(512),
DESC_LONG VARCHAR(2048),
DT_HORS_DELAI DATE,
DT_DEBUT DATE,
DT_FIN DATE,
DT_DEB_INSCRIPTION DATE,
DT_FIN_INSCRIPTION DATE,
DT_DEB_REINSCRIPTION DATE,
DT_FIN_REINSCRIPTION DATE,
DT_ANNULATION DATE,
COMMENTAIRE VARCHAR(2048),
KL_ID NUMBER,
CODE VARCHAR(64),
ORGANISATION_ID NUMBER
) [42001-232]
Error Code: 42001
at
I Have an SpringBoot 2.7.18 with H2 2.3.232, with this SQL for testing:
CREATE TABLE IF NOT EXISTS EXERCICE
(
EXERCICE_ID NUMBER AUTO_INCREMENT,
TYPE_SITE_ID NUMBER,
EXERCICE_META_ID NUMBER,
DESC_COURT VARCHAR(512),
DESC_LONG VARCHAR(2048),
DT_HORS_DELAI DATE,
DT_DEBUT DATE,
DT_FIN DATE,
DT_DEB_INSCRIPTION DATE,
DT_FIN_INSCRIPTION DATE,
DT_DEB_REINSCRIPTION DATE,
DT_FIN_REINSCRIPTION DATE,
DT_ANNULATION DATE,
COMMENTAIRE VARCHAR(2048),
KL_ID NUMBER,
CODE VARCHAR(64),
ORGANISATION_ID NUMBER
);
but when running the tests I have this error:
Caused by: javax.persistence.PersistenceException: Exception [EclipseLink-4002] (Eclipse Persistence Services - 2.7.15.v20240516-53511fdbd8): org.eclipse.persistence.exceptions.DatabaseException
Internal Exception: org.h2.jdbc.JdbcSQLSyntaxErrorException: Syntax error in SQL statement "CREATE TABLE IF NOT EXISTS EXERCICE\000d\000a(\000d\000a EXERCICE_ID NUMBER [*]AUTO_INCREMENT,\000d\000a TYPE_SITE_ID NUMBER,\000d\000a EXERCICE_META_ID NUMBER,\000d\000a DESC_COURT VARCHAR(512),\000d\000a DESC_LONG VARCHAR(2048),\000d\000a DT_HORS_DELAI DATE,\000d\000a DT_DEBUT DATE,\000d\000a DT_FIN DATE,\000d\000a DT_DEB_INSCRIPTION DATE,\000d\000a DT_FIN_INSCRIPTION DATE,\000d\000a DT_DEB_REINSCRIPTION DATE,\000d\000a DT_FIN_REINSCRIPTION DATE,\000d\000a DT_ANNULATION DATE,\000d\000a COMMENTAIRE VARCHAR(2048),\000d\000a KL_ID NUMBER,\000d\000a CODE VARCHAR(64),\000d\000a ORGANISATION_ID NUMBER\000d\000a)"; expected "(, ARRAY, INVISIBLE, VISIBLE, NOT NULL, DEFAULT, GENERATED, ON UPDATE, NOT NULL, DEFAULT ON NULL, SEQUENCE, SELECTIVITY, COMMENT, CONSTRAINT, COMMENT, PRIMARY KEY, UNIQUE, NOT NULL, CHECK, REFERENCES, ,, )"; SQL statement:
CREATE TABLE IF NOT EXISTS EXERCICE
(
EXERCICE_ID NUMBER AUTO_INCREMENT,
TYPE_SITE_ID NUMBER,
EXERCICE_META_ID NUMBER,
DESC_COURT VARCHAR(512),
DESC_LONG VARCHAR(2048),
DT_HORS_DELAI DATE,
DT_DEBUT DATE,
DT_FIN DATE,
DT_DEB_INSCRIPTION DATE,
DT_FIN_INSCRIPTION DATE,
DT_DEB_REINSCRIPTION DATE,
DT_FIN_REINSCRIPTION DATE,
DT_ANNULATION DATE,
COMMENTAIRE VARCHAR(2048),
KL_ID NUMBER,
CODE VARCHAR(64),
ORGANISATION_ID NUMBER
) [42001-232]
Error Code: 42001
at org.eclipse.persistence.internal.jpa.EntityManagerSetupImpl.deploy(EntityManagerSetupImpl.java:855)
at org.eclipse.persistence.internal.jpa.EntityManagerFactoryDelegate.getAbstractSession(EntityManagerFactoryDelegate.java:222)
at org.eclipse.persistence.internal.jpa.EntityManagerFactoryDelegate.getMetamodel(EntityManagerFactoryDelegate.java:679)
at org.eclipse.persistence.internal.jpa.EntityManagerFactoryImpl.getMetamodel(EntityManagerFactoryImpl.java:565)
at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.base/java.lang.reflect.Method.invoke(Method.java:566)
at org.springframework.orm.jpa.AbstractEntityManagerFactoryBean.invokeProxyMethod(AbstractEntityManagerFactoryBean.java:519)
at org.springframework.orm.jpa.AbstractEntityManagerFactoryBean$ManagedEntityManagerFactoryInvocationHandler.invoke(AbstractEntityManagerFactoryBean.java:734)
at com.sun.proxy.$Proxy32.getMetamodel(Unknown Source)
at java.base/java.util.stream.ReferencePipeline$3$1.accept(ReferencePipeline.java:195)
at java.base/java.util.Iterator.forEachRemaining(Iterator.java:133)
at java.base/java.util.Spliterators$IteratorSpliterator.forEachRemaining(Spliterators.java:1801)
at java.base/java.util.stream.AbstractPipeline.copyInto(AbstractPipeline.java:484)
at java.base/java.util.stream.AbstractPipeline.wrapAndCopyInto(AbstractPipeline.java:474)
at java.base/java.util.stream.ReduceOps$ReduceOp.evaluateSequential(ReduceOps.java:913)
at java.base/java.util.stream.AbstractPipeline.evaluate(AbstractPipeline.java:234)
at java.base/java.util.stream.ReferencePipeline.collect(ReferencePipeline.java:578)
at org.springframework.data.jpa.repository.config.JpaMetamodelMappingContextFactoryBean.getMetamodels(JpaMetamodelMappingContextFactoryBean.java:106)
at org.springframework.data.jpa.repository.config.JpaMetamodelMappingContextFactoryBean.createInstance(JpaMetamodelMappingContextFactoryBean.java:80)
at org.springframework.data.jpa.repository.config.JpaMetamodelMappingContextFactoryBean.createInstance(JpaMetamodelMappingContextFactoryBean.java:44)
at org.springframework.beans.factory.config.AbstractFactoryBean.afterPropertiesSet(AbstractFactoryBean.java:142)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1863)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1800)
... 67 common frames omitted
Caused by: org.eclipse.persistence.exceptions.DatabaseException:
Internal Exception: org.h2.jdbc.JdbcSQLSyntaxErrorException: Syntax error in SQL statement "CREATE TABLE IF NOT EXISTS EXERCICE\000d\000a(\000d\000a EXERCICE_ID NUMBER [*]AUTO_INCREMENT,\000d\000a TYPE_SITE_ID NUMBER,\000d\000a EXERCICE_META_ID NUMBER,\000d\000a DESC_COURT VARCHAR(512),\000d\000a DESC_LONG VARCHAR(2048),\000d\000a DT_HORS_DELAI DATE,\000d\000a DT_DEBUT DATE,\000d\000a DT_FIN DATE,\000d\000a DT_DEB_INSCRIPTION DATE,\000d\000a DT_FIN_INSCRIPTION DATE,\000d\000a DT_DEB_REINSCRIPTION DATE,\000d\000a DT_FIN_REINSCRIPTION DATE,\000d\000a DT_ANNULATION DATE,\000d\000a COMMENTAIRE VARCHAR(2048),\000d\000a KL_ID NUMBER,\000d\000a CODE VARCHAR(64),\000d\000a ORGANISATION_ID NUMBER\000d\000a)"; expected "(, ARRAY, INVISIBLE, VISIBLE, NOT NULL, DEFAULT, GENERATED, ON UPDATE, NOT NULL, DEFAULT ON NULL, SEQUENCE, SELECTIVITY, COMMENT, CONSTRAINT, COMMENT, PRIMARY KEY, UNIQUE, NOT NULL, CHECK, REFERENCES, ,, )"; SQL statement:
CREATE TABLE IF NOT EXISTS EXERCICE
(
EXERCICE_ID NUMBER AUTO_INCREMENT,
TYPE_SITE_ID NUMBER,
EXERCICE_META_ID NUMBER,
DESC_COURT VARCHAR(512),
DESC_LONG VARCHAR(2048),
DT_HORS_DELAI DATE,
DT_DEBUT DATE,
DT_FIN DATE,
DT_DEB_INSCRIPTION DATE,
DT_FIN_INSCRIPTION DATE,
DT_DEB_REINSCRIPTION DATE,
DT_FIN_REINSCRIPTION DATE,
DT_ANNULATION DATE,
COMMENTAIRE VARCHAR(2048),
KL_ID NUMBER,
CODE VARCHAR(64),
ORGANISATION_ID NUMBER
) [42001-232]
Error Code: 42001
at
Share
Improve this question
asked yesterday
Nuñito CalzadaNuñito Calzada
2,24253 gold badges197 silver badges326 bronze badges
1
- SQL runs fine in H2 console 2.3.232. Probably some hidden chars in your SQL string. Post your code. – PeterMmm Commented yesterday
2 Answers
Reset to default 1Depending on the version and configuration of your H2 database AUTO_INCREMENT
might not be supported.
See this answer for a variety of how to get the same effective result with a more modern syntax.
In the H2 documentation, it says
AUTO_INCREMENT clauses do not create the primary key constraint automatically
Thus I'm suggesting changing the line which reads:
EXERCICE_ID NUMBER AUTO_INCREMENT,
To be:
EXERCICE_ID PRIMARY KEY AUTO_INCREMENT,
本文标签: javaSpringBoot 2718 with H2 DBStack Overflow
版权声明:本文标题:java - SpringBoot 2.7.18 with H2 DB - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1736281801a1926436.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论