INSERT INTO и конкатенация строк с Python

Я столкнулся с серьезным ударом скорости при вставке данных в мою БД. Из приведенного ниже кода видно, что я просто создаю оператор 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()
11
задан p.campbell 24 May 2011 в 22:28
поделиться