Я столкнулся с серьезным ударом скорости при вставке данных в мою БД. Из приведенного ниже кода видно, что я просто создаю оператор SQL для передачи команде выполнения. Значения верны, и все в порядке, но интерпретатор python, похоже, добавляет и удаляет кавычки из параметров во время выполнения.
Это правильный способ вставки пространственных данных в базу данных.
INSERT INTO my_table(
name, url, id, point_geom, poly_geom)
VALUES ('test', 'http://myurl', '26971012',
ST_GeomFromText('POINT(52.147400 19.050780)',4326),
ST_GeomFromText('POLYGON(( 52.146542 19.050557, bleh, bleh, bleh))',4326));
Это можно проверить в редакторе запросов Postgres ... Теперь, когда я запускаю приведенный ниже код Python, он добавляет двойные кавычки вокруг функции ST_GeomFromText, а затем удаляет кавычки из столбца id.
INSERT INTO my_table(
name, url, id, point_geom, poly_geom)
VALUES ('test', 'http://myurl', 26971012,
"ST_GeomFromText('POINT(52.147400 19.050780)',4326)",
"ST_GeomFromText('POLYGON(( 52.146542 19.050557, 52.148430 19.045527, 52.149525 19.045831, 52.147400 19.050780, 52.147400 19.050780, 52.146542 19.050557))',4326)");
Это вызывает сбой вставки, и PostGIS утверждает, что это неправильная геометрия. Когда я печатаю каждый из параметров для просмотра на экране, в кавычках нет ничего забавного, поэтому я думаю, что проблема должна быть в команде выполнения. Я использую Python 2.7 ... Может ли кто-нибудь помочь, как предотвратить продолжение этого безумия?
conn = psycopg2.connect('dbname=mydb user=postgres password=password')
cur = conn.cursor()
SQL = 'INSERT INTO my_table (name, url, id, point_geom, poly_geom) VALUES (%s,%s,%s,%s,%s);'
Data = name, url, id, point, polygon
#print Data
cur.execute(SQL, Data)
conn.commit()
cur.close()
conn.close()