postgis--PostgreSQL16及其plpython3u扩展

PostgreSQL16及其plpython3u扩展

安装plpython3u拓展常见错误

在安装pg后想用python创建自定义函数,默认是不支持的,但是增加拓展有很多坑,在这里记录以下。

最常见的错误:

错误: 无法加载库 "D:/ProgramFiles/PostgreSQL/13/lib/plpython3.dll": The specified module could not be found.

错误: 无法加载库 "D:/ProgramFiles/PostgreSQL/13/lib/plpython3.dll": The specified module could not be found.

SQL 状态: 58P01

安装postgresql

下载安装postgresql

安装postgis

postgis和postgresql版本号要对应

安装python

版本号要求非常严格,查看这个文件里面有指定版本。

配置环境变量

python需要配置环境变量,postgresql也是,是配置系统环境变量不是用户的。

安装完成后后验证

可以先在命令行验证

复制代码
C:\Users\83832>"D:\ProgramFiles\PostgreSQL\16\bin\psql.exe" -U postgres -d postgres -c "CREATE EXTENSION plpython3u;"
用户 postgres 的口令:

CREATE EXTENSION

C:\Users\83832>"D:\ProgramFiles\PostgreSQL\16\bin\psql.exe" -U postgres -d postgres -c "CREATE OR REPLACE FUNCTION test_py() RETURNS text AS $$ return 'Python works!' $$ LANGUAGE plpython3u; SELECT test_py();"
用户 postgres 的口令:

CREATE FUNCTION
    test_py
---------------
 Python works!
(1 行记录)

pgAdmin 使用

需要先确认进入的数据库是否已经增加了plpython3u 扩展;(默认是postgres数据库 postgis_16_sample默认是没有的)

复制代码
# 增加扩展
CREATE EXTENSION plpython3u;

# 测试创建函数
CREATE OR REPLACE FUNCTION add_numbers(a int, b int)
RETURNS int
AS $$
    return a + b
$$ LANGUAGE plpython3u;

# 调用测试函数
SELECT add_numbers(10, 20);

enceDiagram.html

相关推荐
new Object ~2 小时前
LangChain的短期记忆存储实现
python·langchain
魔都吴所谓2 小时前
【Python】从零构建:IP地理位置查询实战指南
开发语言·python·tcp/ip
测试19983 小时前
使用Python自动化生成接口测试用例
自动化测试·软件测试·python·测试工具·职场和发展·测试用例·接口测试
智算菩萨3 小时前
【Pygame】第10章 游戏状态管理与场景切换机制
python·游戏·pygame
songcream13 小时前
TensorFlow的一些基本概念
人工智能·python·tensorflow
AI逐月5 小时前
解决 ComfyUI 插件安装后 Nanobind 报错问题:soxr 版本冲突原理解读
开发语言·python
AC赳赳老秦5 小时前
Windows 系统 OpenClaw 执行策略报错及管理员权限设置深度解析与实操指南
运维·人工智能·python·django·自动化·媒体·openclaw
软件开发技术深度爱好者5 小时前
用python + pillow实现GUI界面图片GUI处理工具
开发语言·python