0

我已经安装了 pgRouting 并且每当我在 PostgreSQL 中创建一个新数据库时,为了使用 pgRouting 功能,我必须执行 3 个 pgRouting 的 sql 文件,

  • 路由核心
  • routing_core_wrappers
  • routing_core_wrappers

是否可以在创建数据库后不每次执行sql文件就使用pgRouting功能?如何?</p>

我在 Windows 8.1 x64 下使用 PostgreSQL 8.4,谢谢。


更新#1

我已经安装了 PostgreSQL 9.2 并创建了一个名为“test”的数据库,在其中加载了一个 shapefile,但是当我执行下面的 sql 行时,错误消息显示 python 找不到 9.2 服务器,

import sys
import psycopg2

conn = psycopg2.connect("dbname = 'test' user = 'postgres' host = 'localhost' password = 'ntubse40'")
cur = conn.cursor()

query = """
    ALTER TABLE tc_2000_w_area ADD COLUMN source integer;
    ALTER TABLE tc_2000_w_area ADD COLUMN target integer;
    SELECT assign_vertex_id('tc_2000_w_area', 0.0001, 'the_geom', 'gid')
;"""
cur.execute(query)

#print out table and check its change
cur.copy_to(sys.stdout, 'tc_2000_w_area', sep = '|')

cur.close()

>>> 

Traceback (most recent call last):
  File "C:/Users/Heinz/Desktop/python_test/any_test.py", line 4, in <module>
    conn = psycopg2.connect("dbname = 'test' user = 'postgres' host = 'localhost' password = 'ntubse40'")
  File "C:\Python27\lib\site-packages\psycopg2\__init__.py", line 164, in connect
    conn = _connect(dsn, connection_factory=connection_factory, async=async)
OperationalError: 嚴重錯誤:  資料庫"test"不存在

UPDATE#2 我终于解决了更改服务器的问题(只是一个愚蠢的问题,感谢 Craig Ringer!),我尝试了以下代码,成功连接到 9.2 服务器,

import sys
import psycopg2

conn = psycopg2.connect("port = '5433' dbname = 'test' user = 'postgres' host = 'localhost' password = 'xxxx'")
cur = conn.cursor()

query = """
    ALTER TABLE tc_2000_w_area ADD COLUMN source integer;
    ALTER TABLE tc_2000_w_area ADD COLUMN target integer;
    SELECT assign_vertex_id('tc_2000_w_area', 0.0001, 'the_geom', 'gid')
;"""
cur.execute(query)

#print out table and check its change
cur.copy_to(sys.stdout, 'tc_2000_w_area', sep = '|')

cur.close()
4

1 回答 1

0

如上所述,有两种方法可以做到这一点:

  1. 对于 postgres 9.0+,您可以使用创建扩展,例如:

    createdb mynewdb

    psql -c "创建扩展 postgis" mynewdb

    psql -c "创建扩展 pgrouting" mynewdb

  2. 对于 postgres 8.4 创建模板数据库

    createdb template_pgrouting

    psql -c "创建语言 plpgsql" template_pgrouting

    psql -f /path/to/postgis.sql template_pgrouting

    psql -f /path/to/pgrouting.sql template_pgrouting

  3. 使用模板创建一个新数据库

    createdb -T template_pgrouting mynewdb

    createdb -T template_pgrouting anotherdb

在步骤中,我将把确切的文件和路径作为练习留给读者。

于 2014-04-18T00:32:39.003 回答