我使用pg_dump创建一个表转储:
pg_dump -h server1 -U postgres -t np_points gisurfo > D:\np_point.sql
进入psql之后说:
-f D:\np_point.sql
但是获取标准的PostgreSQL表列表。
接下来,我尝试在pgAdmin中执行np_point.sql并获取错误:
ERROR: Syntax error (near: "1")
LINE 78: 1 Сухово 75244822005 75644000 Челябинская обл. Нязепетровски...
这个sql的片段,我收到错误:
COPY np_point (gid, full_name, okato, oktmo, obl_name, region_nam, the_geom) FROM stdin;
1 Сухово 75244822005 75644000 Челябинская обл. Нязепетровский район 0101000020E6100000312A7936BD9F4D402A3C580DE9FF4B40
如何从sql文件恢复表?
更新
PostgreSQL 8.4
sql文件的第一部分。
PostgreSQL database dump
SET statement_timeout = 0;
SET client_encoding = 'UTF8';
SET standard_conforming_strings = off;
SET check_function_bodies = false;
SET client_min_messages = warning;
SET escape_string_warning = off;
SET search_path = public, pg_catalog;
SET default_tablespace = '';
SET default_with_oids = false;
--
-- Name: np_point; Type: TABLE; Schema: public; Owner: postgres; Tablespace:
--
CREATE TABLE np_point (
gid integer NOT NULL,
full_name character varying(254),
okato character varying(254),
oktmo character varying(254),
obl_name character varying(254),
region_nam character varying(254),
the_geom geometry,
CONSTRAINT enforce_dims_the_geom CHECK ((st_ndims(the_geom) = 2)),
CONSTRAINT enforce_geotype_the_geom CHECK (((geometrytype(the_geom) = 'POINT'::text) OR (the_geom IS NULL))),
CONSTRAINT enforce_srid_the_geom CHECK ((st_srid(the_geom) = 4326))
);
答案 0 :(得分:1)
你是否在目的地db中安装了posgis?如果没有,请先安装postgis。
如果您安装postgis但仍有问题,请尝试转储没有几何文件的表 并在另一个数据库中恢复它,并查看问题是否仍然出现。