如何解决从 Postgres 转储在 HyperSQL 中不起作用
我需要从 Postgres 服务器获取转储并在内存中的 HyperSQL 服务器中运行它。
例如,让我们考虑以下查询来创建客户表:
CREATE TABLE customer (
id integer DEFAULT nextval('public.customer_seq'::regclass) NOT NULL,name character varying(255) DEFAULT NULL::character varying,contact character varying(255) DEFAULT NULL::character varying,address character varying(255) DEFAULT NULL::character varying);
上述查询是从 pg_dump 生成的,但是当我在 HyperSQL 上运行相同的查询时,它无法识别以 ::
开头的内容,在这种情况下为 ::character varying
和 {{ 1}}。
在 ::regclass
或 Postgres 手册中找不到任何有用的东西来从转储中排除这些东西。
现在我正在用 Java 以编程方式用其他不需要的东西替换这些东西。有什么更好的方法吗?
注意:我已经在使用 pg_dump
,但在这种情况下没有帮助。
解决方法
NULL 是默认的默认值。您可以通过执行以下操作更改您的表以摆脱显式(显然毫无意义)的默认子句:
alter table customer alter name drop default;
等等。我有点惊讶 pg_dump 没有为你丢弃它。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。