sql >> Databasteknik >  >> RDS >> PostgreSQL

Modulen hittades inte vid import av ett Python-paket inom en plpython3u-procedur

Förutom andra miljövariabler som PGDATA i ett skalskript (pg_service.sh), ställ in PYTHONPATH='/path/to/python:/path/to/your/module'

T.ex. cat /Users/postgres/pg_service.sh

export PGDATABASE=postgres
export PGUSER=postgres
export PGPORT=5432
export PATH=/Library/PostgreSQL/11/bin:$PATH
export PGLOCALEDIR=/Library/PostgreSQL/11/share/locale
export PYTHONUSERBASE=/Users/postgres/packaging_tutorial
export PYTHONPATH=/Library/edb/languagepack-11/Python-3.6:$PYTHONUSERBASE
pg_ctl -D /Library/PostgreSQL/11/data -l /Users/postgres/logfile $1

Starta servern:

> sudo -u postgres /Users/postgres/pg_service.sh start
waiting for server to start.... done
server started 

/Users/postgres/packaging_tutorial/example_pkg/__init__.py :

def retpy3():
    return 7/5

sidfunktion:

CREATE OR REPLACE FUNCTION expy3()
RETURNS text
LANGUAGE plpython3u
AS $$
import example_pkg
return example_pkg.retpy3()
$$;

Utdata

psql  -c 'select * from expy3()';
 expy3
--------
 1.4



  1. Hur man importerar formfil till MySQL

  2. Strapi + Cloud SQL för MySQL på Google App Engine - Servern kunde inte starta ordentligt Fel:getaddriinfo EAI_AGAIN

  3. Infoga flera poster i Oracle

  4. Vilken är den bästa kolumntypen för ett postnummer i USA?