使用Python SQLAlchemy将POSTGIS数据类型插入PostgresDB

时间:2017-05-22 08:33:44

标签: postgresql python-3.x sqlalchemy postgis geoalchemy

我正在尝试使用SQLalchemy将Linestring,Polygon和其他数据类型的POSTGIS值插入postgres数据库并遇到这些错误:

这是使用postgres db命令创建的表的Schema:

                 Table "public.test"
    Column    |           Type            | Modifiers 
--------------+---------------------------+-----------
 name         | text                      | 
 wkb_geometry | geometry(LineString,4326) | 

已经使用DDL语句创建了postgres表的模式。

我尝试使用psycopg2从xml插入gml值,并使用以下内容成功插入:

wkb_geometry_value = """<gml:LineString xmlns:gml="http://www.opengis.net/gml" xmlns="urn:hera:xml:ns:DataTypes:2.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:hera-drex="urn:hera:xml:ns:exchange:2.0" xmlns:hera-sgftad="urn:hera:xml:ns:sft:2.0" xmlns:hera-rifdt="urn:hera:xml:nsftypes:2.0" xmlns:wfs="http://www.opengis.org/wfs: " xmlns:gb="http://www.opengis.org/gb" xmlns:georss="http://www.opengis.netgeorss"><gml:posList>34.216 -210.54 34.46 -119.4 34.65 -139.84</gml:posList>\</gml:LineString>"""

sql = INSERT INTO test('name','wkb_geometry)VALUES('BOB', ST_SetSRID(ST_GeomFromGML('{}',4326)))
cursor.execute(sql)

输出 - &gt;成功插入

但是当我使用下面的内容时,它无法使用sqlalchemy和geoalchemy

import sqlalchemy                                                           
from sqlalchemy import create_engine            
from sqlalchemy import Table, Column, Integer, String, MetaData, ForeignKey
from sqlalchemy import inspect 

sql = """INSERT INTO test (name, wkb_geometry) VALUES ('{}', ST_GeomFromEWKT('{}'))""".format('BOB', wkb_geometry_value)
engine = create_engine('postgresql://username:password@localhost/dbname')

 with engine.connect() as con:
    rs = con.execute(sql)

输出 ==&gt; InternalError:(psycopg2.InternalError)解析错误 - 无效几何

如何使用SQLalchemy和geoalchemy将GIS数据类型插入PostgresDB。

任何帮助将不胜感激 谢谢!!!! 我

0 个答案:

没有答案