2

我有两个 postgreSQL 实例,一个作为数据源(端口 5433),另一个作为数据访问层(端口 5432 上的外部数据包装器的主机)。

我想导入 postgreSQL 表(Dzlog)的模式,这样我就不必映射“CREATE FOREIGN TABLE”中的每一列。因此,我有以下命令:

engine = create_engine('pgfdw://postgres:test123@localhost:5432/mydb')
connection = engine.connect()
connection.execute("""CREATE SERVER pgfdw_server_1 FOREIGN DATA WRAPPER postgres_fdw 
OPTIONS (dbname 'sorucedb', port '5433', host 'localhost');""")

connection.execute("""CREATE USER MAPPING FOR postgres SERVER `pgfdw_server_1 
OPTIONS (user 'postgres',password 'password')""")`

connection.execute ("""CREATE SCHEMA imported;""")
connection.execute("""IMPORT FOREIGN SCHEMA public LIMIT TO(Dzlog) FROM SERVER pgfdw_server_1 INTO imported;""")

现在,如何使用这个导入的模式创建外部表?

更新:

因此,如果通过导入外部模式 (Dzlog) 已经创建了外部表,我使用以下 select 语句:

connection.execute("""SELECT sheetId FROM importing.Dzlog WHERE dz(30)=-5;""")

ProgrammingError:(psycopg2.ProgrammingError)关系“Dzlog”不存在

在 psql 中也不存在关系

4

0 回答 0