Как вызвать функцию с параметром json в Postgres - PullRequest
0 голосов
/ 26 сентября 2018

Мне нужно передать объект json в функцию, но она не работает:

import psycopg2
cur.execute(" SELECT mrp_sp_insert_jobdef( %s )",(json(_jobdef),) )

TypeError: 'module' object is not callable

В качестве альтернативы:

cur.execute(" SELECT mrp_sp_insert_jobdef( % )",(json.dumps(_jobdef),) )

ValueError: unsupported format character ' ' (0x20) at index 31

1 Ответ

0 голосов
/ 26 сентября 2018

Вы можете использовать упаковщик psycopg2.extras.Json(adapted, dumps=None), пример:

import psycopg2
from psycopg2.extras import Json

conn = psycopg2.connect("dbname=test user=postgres password=password")
cur = conn.cursor()

_jobdef = {'id': 1, 'name': 'product', 'amount': 230}
cur.execute("SELECT mrp_sp_insert_jobdef( %s )", (Json(_jobdef),) )
...