Liquibase Oracle 日期类型不受支持的错误
Liquibase Oracle Date Type unsupported error
我的更改集中有一个这样定义的列:
<column name="LAST_MOD_TIME" type="date"/>
我有这样的插入(从另一个数据库生成):
<column name="LAST_MOD_TIME" valueDate="2009-05-30T00:39:40"/>
当我 运行 使用 mvn liquibase:update
它会生成如下错误:
[Failed SQL: INSERT INTO .... , UNSUPPORTED:2009-05-30T00:39:40]
删除 T
没有任何区别。唯一可行的方法是将其和 HH:MI:SS
值一起远程。
我在 Oracle 中尝试了 alter session NLS_DATE_FORMAT
- 但这可能需要在系统范围内进行,我还没有弄清楚。或者以某种方式将其添加到 Liquibase 更改文件中。
感谢任何帮助。
堆栈跟踪:
org.apache.maven.lifecycle.LifecycleExecutionException: 无法执行目标 org.liquibase:liquibase-maven-plugin:3.6.1:update (default-cli) 项目 liquibase.ecom: 错误设置或 运行ning Liquibase:变更集迁移失败 src/main/resources/liquibase/db-prop-changelog-4.xml::1531127783280-4::user:
原因:liquibase.exception.DatabaseException:ORA-00917:缺少逗号
at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:216)
at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:153)
at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:145)
at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject(LifecycleModuleBuilder.java:116)
at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject(LifecycleModuleBuilder.java:80)
at org.apache.maven.lifecycle.internal.builder.singlethreaded.SingleThreadedBuilder.build(SingleThreadedBuilder.java:51)
at org.apache.maven.lifecycle.internal.LifecycleStarter.execute(LifecycleStarter.java:120)
at org.apache.maven.DefaultMaven.doExecute(DefaultMaven.java:355)
at org.apache.maven.DefaultMaven.execute(DefaultMaven.java:155)
at org.apache.maven.cli.MavenCli.execute(MavenCli.java:584)
at org.apache.maven.cli.MavenCli.doMain(MavenCli.java:216)
at org.apache.maven.cli.MavenCli.main(MavenCli.java:160)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:483)
at org.codehaus.plexus.classworlds.launcher.Launcher.launchEnhanced(Launcher.java:289)
at org.codehaus.plexus.classworlds.launcher.Launcher.launch(Launcher.java:229)
at org.codehaus.plexus.classworlds.launcher.Launcher.mainWithExitCode(Launcher.java:415)
at org.codehaus.plexus.classworlds.launcher.Launcher.main(Launcher.java:356)
at org.liquibase.maven.plugins.AbstractLiquibaseMojo.execute(AbstractLiquibaseMojo.java:370)
at org.apache.maven.plugin.DefaultBuildPluginManager.executeMojo(DefaultBuildPluginManager.java:132)
at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:208)
... 19 more
原因:liquibase.exception.MigrationFailedException:变更集迁移失败 src/main/resources/liquibase/db-ec-prop-changelog-4。xml::1531127783280-4::user:
原因:liquibase.exception.DatabaseException:ORA-00917:缺少逗号
at liquibase.changelog.ChangeSet.execute(ChangeSet.java:637)
at liquibase.changelog.visitor.UpdateVisitor.visit(UpdateVisitor.java:53)
at liquibase.changelog.ChangeLogIterator.run(ChangeLogIterator.java:78)
at liquibase.Liquibase.update(Liquibase.java:202)
at liquibase.Liquibase.update(Liquibase.java:179)
at liquibase.Liquibase.update(Liquibase.java:334)
at org.liquibase.maven.plugins.LiquibaseUpdate.doUpdate(LiquibaseUpdate.java:33)
at org.liquibase.maven.plugins.AbstractLiquibaseUpdateMojo.performLiquibaseTask(AbstractLiquibaseUpdateMojo.java:30)
at org.liquibase.maven.plugins.AbstractLiquibaseMojo.execute(AbstractLiquibaseMojo.java:366)
... 21 more
原因:liquibase.exception.DatabaseException:ORA-00917:缺少逗号
[失败 SQL:插入 属性(OBJECT_ID、名称、语言环境、值、描述、INSERT_DATE_TIME、LAST_MOD_TIME、LAST_MODIFIED_BY、LAST_ACCESS_AUDIT_TIME, 版本, ENVIRONMENT_NAME) 值 (60471, 'INFORMATION', 'ie', 'Y', 'INFORMATION', UNSUPPORTED:2018-05-30T00: 39:40,UNSUPPORTED:2018-05-30T00:39:40,'abc',UNSUPPORTED:2018-05-30T00:39:40,1,空)]
在 liquibase.executor.jvm.JdbcExecutor$ExecuteStatementCallback.doInStatement(JdbcExecutor.java:356)
在 liquibase.executor.jvm.JdbcExecutor. 执行(JdbcExecutor.java:57)
在 liquibase.executor.jvm.JdbcExecutor.execute(JdbcExecutor.java:125)
在 liquibase.database.AbstractJdbcDatabase.execute(AbstractJdbcDatabase.java:1229)
在 liquibase.database.AbstractJdbcDatabase.execute 语句(AbstractJdbcDatabase.java:1211)
在 liquibase.changelog.ChangeSet.execute(ChangeSet.java:600)
... 还有 29 个
at oracle.jdbc.driver.T4CTTIoer11.processError(T4CTTIoer11.java:494)
我不知道 Liquibase 是如何处理的,但 Oracle 支持 ISO SQL
日期和时间戳文字:
Datetime Literals
Oracle Database supports four datetime datatypes: DATE, TIMESTAMP,
TIMESTAMP WITH TIME ZONE, and TIMESTAMP WITH LOCAL TIME ZONE.
DATE '1998-12-25'
最后我找到的唯一方法是:
像这样添加触发器:
CREATE OR REPLACE TRIGGER LOGINTRG
2 AFTER LOGON ON DATABASE
3 BEGIN
4 EXECUTE IMMEDIATE 'ALTER SESSION SET NLS_DATE_FORMAT=''YYYY-MM-DD"T"HH24:MI:SS''';
5 END LOGINTRG;
6 /
和
将 valueDate 更改为插入中的值(注意:此更改日志是使用 generateLog 选项从现有的 oracle 数据库生成的)。
<insert tableName="MY_TABLE">
<!--column name="INSERT_DATE_TIME" valueDate="2009-05-30T00:39:40"/-->
<column name="INSERT_DATE_TIME" value="2009-05-30T00:39:40"/>
..
..
我的更改集中有一个这样定义的列:
<column name="LAST_MOD_TIME" type="date"/>
我有这样的插入(从另一个数据库生成):
<column name="LAST_MOD_TIME" valueDate="2009-05-30T00:39:40"/>
当我 运行 使用 mvn liquibase:update
它会生成如下错误:
[Failed SQL: INSERT INTO .... , UNSUPPORTED:2009-05-30T00:39:40]
删除 T
没有任何区别。唯一可行的方法是将其和 HH:MI:SS
值一起远程。
我在 Oracle 中尝试了 alter session NLS_DATE_FORMAT
- 但这可能需要在系统范围内进行,我还没有弄清楚。或者以某种方式将其添加到 Liquibase 更改文件中。
感谢任何帮助。
堆栈跟踪:
org.apache.maven.lifecycle.LifecycleExecutionException: 无法执行目标 org.liquibase:liquibase-maven-plugin:3.6.1:update (default-cli) 项目 liquibase.ecom: 错误设置或 运行ning Liquibase:变更集迁移失败 src/main/resources/liquibase/db-prop-changelog-4.xml::1531127783280-4::user: 原因:liquibase.exception.DatabaseException:ORA-00917:缺少逗号
at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:216)
at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:153)
at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:145)
at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject(LifecycleModuleBuilder.java:116)
at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject(LifecycleModuleBuilder.java:80)
at org.apache.maven.lifecycle.internal.builder.singlethreaded.SingleThreadedBuilder.build(SingleThreadedBuilder.java:51)
at org.apache.maven.lifecycle.internal.LifecycleStarter.execute(LifecycleStarter.java:120)
at org.apache.maven.DefaultMaven.doExecute(DefaultMaven.java:355)
at org.apache.maven.DefaultMaven.execute(DefaultMaven.java:155)
at org.apache.maven.cli.MavenCli.execute(MavenCli.java:584)
at org.apache.maven.cli.MavenCli.doMain(MavenCli.java:216)
at org.apache.maven.cli.MavenCli.main(MavenCli.java:160)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:483)
at org.codehaus.plexus.classworlds.launcher.Launcher.launchEnhanced(Launcher.java:289)
at org.codehaus.plexus.classworlds.launcher.Launcher.launch(Launcher.java:229)
at org.codehaus.plexus.classworlds.launcher.Launcher.mainWithExitCode(Launcher.java:415)
at org.codehaus.plexus.classworlds.launcher.Launcher.main(Launcher.java:356)
at org.liquibase.maven.plugins.AbstractLiquibaseMojo.execute(AbstractLiquibaseMojo.java:370)
at org.apache.maven.plugin.DefaultBuildPluginManager.executeMojo(DefaultBuildPluginManager.java:132)
at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:208)
... 19 more
原因:liquibase.exception.MigrationFailedException:变更集迁移失败 src/main/resources/liquibase/db-ec-prop-changelog-4。xml::1531127783280-4::user: 原因:liquibase.exception.DatabaseException:ORA-00917:缺少逗号
at liquibase.changelog.ChangeSet.execute(ChangeSet.java:637)
at liquibase.changelog.visitor.UpdateVisitor.visit(UpdateVisitor.java:53)
at liquibase.changelog.ChangeLogIterator.run(ChangeLogIterator.java:78)
at liquibase.Liquibase.update(Liquibase.java:202)
at liquibase.Liquibase.update(Liquibase.java:179)
at liquibase.Liquibase.update(Liquibase.java:334)
at org.liquibase.maven.plugins.LiquibaseUpdate.doUpdate(LiquibaseUpdate.java:33)
at org.liquibase.maven.plugins.AbstractLiquibaseUpdateMojo.performLiquibaseTask(AbstractLiquibaseUpdateMojo.java:30)
at org.liquibase.maven.plugins.AbstractLiquibaseMojo.execute(AbstractLiquibaseMojo.java:366)
... 21 more
原因:liquibase.exception.DatabaseException:ORA-00917:缺少逗号 [失败 SQL:插入 属性(OBJECT_ID、名称、语言环境、值、描述、INSERT_DATE_TIME、LAST_MOD_TIME、LAST_MODIFIED_BY、LAST_ACCESS_AUDIT_TIME, 版本, ENVIRONMENT_NAME) 值 (60471, 'INFORMATION', 'ie', 'Y', 'INFORMATION', UNSUPPORTED:2018-05-30T00: 39:40,UNSUPPORTED:2018-05-30T00:39:40,'abc',UNSUPPORTED:2018-05-30T00:39:40,1,空)] 在 liquibase.executor.jvm.JdbcExecutor$ExecuteStatementCallback.doInStatement(JdbcExecutor.java:356) 在 liquibase.executor.jvm.JdbcExecutor. 执行(JdbcExecutor.java:57) 在 liquibase.executor.jvm.JdbcExecutor.execute(JdbcExecutor.java:125) 在 liquibase.database.AbstractJdbcDatabase.execute(AbstractJdbcDatabase.java:1229) 在 liquibase.database.AbstractJdbcDatabase.execute 语句(AbstractJdbcDatabase.java:1211) 在 liquibase.changelog.ChangeSet.execute(ChangeSet.java:600) ... 还有 29 个
at oracle.jdbc.driver.T4CTTIoer11.processError(T4CTTIoer11.java:494)
我不知道 Liquibase 是如何处理的,但 Oracle 支持 ISO SQL 日期和时间戳文字:
Datetime Literals
Oracle Database supports four datetime datatypes: DATE, TIMESTAMP, TIMESTAMP WITH TIME ZONE, and TIMESTAMP WITH LOCAL TIME ZONE.
DATE '1998-12-25'
最后我找到的唯一方法是:
像这样添加触发器:
CREATE OR REPLACE TRIGGER LOGINTRG 2 AFTER LOGON ON DATABASE 3 BEGIN 4 EXECUTE IMMEDIATE 'ALTER SESSION SET NLS_DATE_FORMAT=''YYYY-MM-DD"T"HH24:MI:SS'''; 5 END LOGINTRG; 6 /
和
将 valueDate 更改为插入中的值(注意:此更改日志是使用 generateLog 选项从现有的 oracle 数据库生成的)。
<insert tableName="MY_TABLE"> <!--column name="INSERT_DATE_TIME" valueDate="2009-05-30T00:39:40"/--> <column name="INSERT_DATE_TIME" value="2009-05-30T00:39:40"/> .. ..