首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >原因: liquibase.exception.DatabaseException: ERROR:对于包含使用报价字符的数据的liquibase,在",“处或附近出现语法错误

原因: liquibase.exception.DatabaseException: ERROR:对于包含使用报价字符的数据的liquibase,在",“处或附近出现语法错误
EN

Stack Overflow用户
提问于 2020-08-15 18:11:51
回答 1查看 598关注 0票数 0

我得到了这个错误

代码语言:javascript
复制
mental-app_1            |      Reason: liquibase.exception.DatabaseException: ERROR: syntax error at or near ","
mental-app_1            |   Position: 55 [Failed SQL: DO
mental-app_1            | $$
mental-app_1            | BEGIN
mental-app_1            | UPDATE public.training SET active_since = , active_until = , conditions = 'obj.trainingColumns = [1,2];', game_id = 28, identificator = '3_1', subject_id = 1 WHERE id = 1;
mental-app_1            | IF not found THEN
mental-app_1            | INSERT INTO public.training (id, active_since, active_until, identificator, conditions, game_id, subject_id) VALUES (1, , , '3_1', 'obj.trainingColumns = [1,2];', 28, 1);
mental-app_1            | END IF;
mental-app_1            | END;
mental-app_1            | $$
mental-app_1            | LANGUAGE plpgsql;]

当执行变更集的以下部分时

代码语言:javascript
复制
<loadUpdateData onlyUpdate="true" quotchar='"'
            file="config/liquibase/data/training.csv"
            separator=";"
            tableName="training"  primaryKey="id">
            <column name="id" type="numeric"/>
            <column name="active_since" type="datetime"/>
            <column name="active_until" type="datetime"/>
            <column name="identificator" type="string"/>
            <column name="conditions" type="string"/>
            <column name="game_id" type="numeric"/>
            <column name="subject_id" type="numeric"/>
            <!-- jhipster-needle-liquibase-add-loadcolumn - JHipster (and/or extensions) can add load columns here, do not remove-->
        </loadUpdateData>

对于这类数据

代码语言:javascript
复制
id;active_since;active_until;identificator;conditions;game_id;subject_id
1;;;3_1;"obj.trainingColumns = [1,2];";28;1

with dataset的变更集设置有什么问题?更改为

代码语言:javascript
复制
id;active_since;active_until;identificator;conditions;game_id;subject_id
1;"";"";3_1;"obj.trainingColumns = [1,2];";28;1

导致了相同的结果。这就是PostgreSQL。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-08-21 00:20:29

尽管还不清楚为什么会抛出异常,但我已经成功地从dataset中删除了active_sinceactive_to列,并从changeset conf中删除了它们。但是直到我得到条件列的引用字符串,例如“obj.trainingColumns = [1,2];” 空的 active_sinceactive_to 没问题。 所以,“obj.trainingColumns = [1,2];”的共存 并且该字段为空是至关重要的

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63424856

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档