在Docker中安装PostgreSQL的ODBC驱动并添加Python测试代码
# 使用官方的Ubuntu镜像作为基础镜像
FROM ubuntu:20.04
# 设置环境变量以避免交互式安装提示
ENV DEBIAN_FRONTEND=noninteractive
# 更新包列表并安装必要的软件包
RUN apt-get update && \
apt-get install -y \
build-essential \
unixodbc \
unixodbc-dev \
odbcinst \
wget \
python3 \
python3-pip \
curl \
gnupg && \
apt-get clean && \
rm -rf /var/lib/apt/lists/*
# 安装 PostgreSQL ODBC 驱动
RUN apt-get update && \
apt-get install -y odbc-postgresql && \
apt-get clean && \
rm -rf /var/lib/apt/lists/*
# 配置 ODBC 驱动
RUN echo "[PostgreSQL]" > /etc/odbcinst.ini && \
echo "Description = ODBC for PostgreSQL" >> /etc/odbcinst.ini && \
echo "Driver = /usr/lib/x86_64-linux-gnu/odbc/psqlodbcw.so" >> /etc/odbcinst.ini && \
echo "Setup = /usr/lib/x86_64-linux-gnu/odbc/libodbcpsqlS.so" >> /etc/odbcinst.ini && \
echo "Driver64 = /usr/lib/x86_64-linux-gnu/odbc/psqlodbcw.so" >> /etc/odbcinst.ini && \
echo "Setup64 = /usr/lib/x86_64-linux-gnu/odbc/libodbcpsqlS.so" >> /etc/odbcinst.ini && \
echo "FileUsage = 1" >> /etc/odbcinst.ini
# 配置 ODBC 数据源
RUN echo "[PostgreSQLDataSource]" > /etc/odbc.ini && \
echo "Driver = PostgreSQL" >> /etc/odbc.ini && \
echo "Servername = localhost" >> /etc/odbc.ini && \
echo "Port = 5432" >> /etc/odbc.ini && \
echo "Database = testdb" >> /etc/odbc.ini && \
echo "Username = postgres" >> /etc/odbc.ini && \
echo "Password = YOUR_PASSWORD" >> /etc/odbc.ini && \
echo "ReadOnly = No" >> /etc/odbc.ini && \
echo "RowVersioning = No" >> /etc/odbc.ini && \
echo "ShowSystemTables = No" >> /etc/odbc.ini && \
echo "ConnSettings = " >> /etc/odbc.ini
# 设置默认命令
#CMD ["bash"]
# 安装 pyodbc 用于测试连接
RUN pip3 install pyodbc
# 添加测试脚本
COPY pgtest_odbc.py /pgtest_odbc.py
# 设置默认命令
CMD ["python3", "/pgtest_odbc.py"]
Python测试代码:
import pyodbc
# 配置数据库连接
dsn = 'PostgreSQLDataSource'
user = 'postgres'
password = 'YOUR_PASSWORD'
database = 'testdb'
# 创建连接字符串
conn_str = f'DSN={dsn};UID={user};PWD={password};DATABASE={database}'
# 尝试连接到数据库
try:
conn = pyodbc.connect(conn_str)
print("Connected to the database successfully!")
conn.close()
except Exception as e:
print(f"Failed to connect to the database: {e}")
__EOF__

本文作者:pccai
本文链接:https://www.cnblogs.com/pccai/p/18203799.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
本文链接:https://www.cnblogs.com/pccai/p/18203799.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
msn: pccai1983@hotmail.com
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!