如何在 Postgres 中使用 json 参数调用函数
How to call a function with json parameter in Postgres
我必须将 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
您可以使用包装器 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),) )
我必须将 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
您可以使用包装器 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),) )