Ubuntu Python数据库连接怎样配置
Ubuntu 下 Python 数据库连接配置指南

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈
一 准备与安装
万事开头难,配置的第一步是把环境准备好。别担心,跟着下面这几步走,基础环境很快就能搭建起来。
更新软件源并安装数据库(按需其一或多项)
- MySQL:打开终端,执行
sudo apt update && sudo apt install mysql-server。 - PostgreSQL:同样是先更新,再安装:
sudo apt update && sudo apt install postgresql postgresql-contrib。 - SQLite:这个通常系统已经自带,如果需要开发头文件,可以运行
sudo apt install sqlite3 libsqlite3-dev。
安装 Python 驱动(与所用数据库匹配)
- MySQL:通过 pip 安装
mysql-connector-python或PyMySQL。 - PostgreSQL:安装
psycopg2或更便捷的psycopg2-binary。 - SQLite:Python 内置了
sqlite3模块,无需额外安装,开箱即用。
初始化与安全(如安装的是 MySQL)
- 安装完成后,强烈建议执行
sudo mysql_secure_installation来完成基础安全加固,比如设置 root 密码、移除匿名用户等操作。
二 数据库与账户配置
数据库服务装好了,接下来就是创建我们自己的数据库和用户。不同数据库的操作略有差异,这里分别说明。
PostgreSQL
- 首先,切换到 postgres 系统用户并进入交互终端:
sudo -u postgres psql。 - 在 psql 命令行中,依次执行以下命令来创建数据库、用户并授权:
CREATE DATABASE yourdatabase;CREATE USER yourusername WITH ENCRYPTED PASSWORD ‘yourpassword’;GRANT ALL PRIVILEGES ON DATABASE yourdatabase TO yourusername;- 最后输入
\q退出。
MySQL
- 使用 root 账户登录:
mysql -u root -p。 - 创建一个数据库,并指定字符集以支持完整的 UTF-8(如表情符号):
CREATE DATABASE yourdatabase CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci; - 创建用户并授权(以下示例仅允许从本机连接):
CREATE USER ‘yourusername’@‘localhost’ IDENTIFIED BY ‘yourpassword’;GRANT ALL PRIVILEGES ON yourdatabase.* TO ‘yourusername’@‘localhost’;FLUSH PRIVILEGES;
- 如果需要远程访问,则需要创建用户如
‘yourusername’@‘%’,并确保服务器的防火墙或云服务商的安全组放行了 3306 端口。另外,MySQL 8 常见的认证插件问题,可以用这条命令解决:ALTER USER ‘root’@‘localhost’ IDENTIFIED WITH mysql_native_password BY ‘yourpassword’;
三 连接示例
理论说再多,不如一行代码。下面分别给出三种数据库在 Python 中的连接和基本操作示例,你可以直接复制修改。
MySQL(使用 mysql-connector-python)
import mysql.connector
from mysql.connector import Error
try:
conn = mysql.connector.connect(
host=‘localhost’,
port=3306,
database=‘yourdatabase’,
user=‘yourusername’,
password=‘yourpassword’,
charset=‘utf8mb4’
)
cur = conn.cursor()
cur.execute(“SELECT DATABASE();”)
print(cur.fetchone())
except Error as e:
print(“MySQL error:”, e)
finally:
if conn.is_connected():
cur.close()
conn.close()
PostgreSQL(使用 psycopg2)
import psycopg2
try:
conn = psycopg2.connect(
dbname=‘yourdatabase’,
user=‘yourusername’,
password=‘yourpassword’,
host=‘localhost’,
port=5432
)
cur = conn.cursor()
cur.execute(“SELECT version();”)
print(cur.fetchone())
except Exception as e:
print(“PostgreSQL error:”, e)
finally:
if conn:
cur.close()
conn.close()
SQLite(使用内置模块)
import sqlite3
conn = sqlite3.connect(‘yourdatabase.db’)
cur = conn.cursor()
cur.execute(‘’‘CREATE TABLE IF NOT EXISTS t(id INTEGER PRIMARY KEY, name TEXT)’‘’)
conn.commit()
cur.execute(“INSERT INTO t(name) VALUES (?)”, (“Alice”,))
for row in cur.execute(“SELECT * FROM t”):
print(row)
conn.close()
四 常见问题与排查
配置过程很少一帆风顺,遇到问题别慌。下面这几个是高频“拦路虎”,附上了排查思路。
- Access denied / plugin auth_socket
- 现象:root 用户在本地都连不上,或者只有系统用户能连。
- 处理:在 MySQL 中执行
ALTER USER ‘root’@‘localhost’ IDENTIFIED WITH mysql_native_password BY ‘newpass’;或者,更规范的做法是创建一个专用用户并授予目标数据库的权限。
- 1044 Access denied for user
- 现象:不指定数据库能连,一指定就连不上。
- 处理:检查用户权限,执行
GRANT ALL PRIVILEGES ON db_name.* TO ‘user’@‘host’; FLUSH PRIVILEGES;确保授权到位。
- 2002 Can’t connect to MySQL server
- 现象:连接被拒绝或超时。
- 处理:首先确认服务是否在运行:
sudo systemctl status mysql。然后检查 3306 端口是否在监听,以及服务器防火墙或云平台安全组规则是否放行。如果是远程连接,确保使用了正确的主机地址和允许远程登录的账户。
- 字符集乱码
- 处理:确保数据库、表以及连接字符串三方统一使用
utf8mb4字符集,在连接参数中加入charset=‘utf8mb4’。
- 处理:确保数据库、表以及连接字符串三方统一使用
相关攻略
在 Ubuntu 上更新 Python 的可选方案与步骤 一 方法总览与选择建议 面对 Ubuntu 系统上 Python 版本的更新需求,其实有几种主流路径可选。每种方法都有其特定的适用场景,选择的关键在于平衡便捷性、隔离性与对现有系统的影响。 简单来说,你可以考虑以下四种方案: 使用 APT +
在 Ubuntu 上安装与运行 Python 程序 一、安装 Python 解释器 万事开头难,但安装Python解释器这事儿,其实不难。关键在于选对方法。 使用系统包管理器安装(推荐) 打开终端,先更新软件源索引,然后直接安装:sudo apt update && sudo apt install
Ubuntu 中 Python 的安装与环境配置教程 一 安装前准备 在开始安装之前,先做好这几项准备工作,能让后续过程顺畅不少。 更新索引并升级系统: 打开终端,首先运行这条命令,确保你的软件包列表是最新的,同时升级所有可更新的包: sudo apt update && sudo apt upgr
在 Ubuntu 上安装与配置 Python 环境 一 快速开始 APT 安装 对于大多数用户来说,最直接、最省心的方式,莫过于使用 Ubuntu 自带的包管理器 APT。这个方法的好处是,安装的 Python 与系统其他组件的兼容性最好,几乎不会出现依赖冲突的问题。 更新索引并安装基础组件: su
优化Ubuntu上的PHP会话管理 想让你的Ubuntu服务器上PHP应用跑得更稳、更快、更安全吗?会话管理这块,往往是性能瓶颈和安全风险的藏身之处。今天,我们就来聊聊几个立竿见影的优化策略。 1 选择合适的会话存储方式 别总让会话数据躺在默认的文件系统里。随着流量增长,文件I O很容易成为拖慢应
热门专题
热门推荐
卡尔达诺ADA:行情监控与高效投资指南 在加密货币市场,卡尔达诺(ADA)的价格走势一直是投资者关注的焦点。其价格波动不仅牵动人心,更直接关系到投资决策的成败。根据最新行情,ADA的价格约为0 801253美元(数据仅供参考,市场实时变化)。想要精准把握这样的波动,一款得力的工具必不可少。接下来要介
Debian上排查与修复Ja va运行时错误的实用流程 遇到Ja va程序在Debian上跑不起来,先别急着抓狂。这事儿其实有章可循,按照一套清晰的流程走下来,大部分问题都能迎刃而解。下面这份指南,就帮你把从快速定位到深度诊断的路径,都梳理清楚了。 一 快速定位与通用修复 排查的第一步,往往是那些最
松下电动剃须刀刀头更换全指南:自己动手,其实很简单 很多朋友可能不知道,手上那台松下电动剃须刀的刀头,其实完全可以自己拆卸和更换,根本不需要专门跑一趟维修点。这可不是什么“民间偏方”,而是松下官方设计的一部分。从ES8953到ES9932C、ES5821这些主流型号,刀网底座和内刀片都采用了模块化的
传真机如何实现多页连续复印?掌握专业设备的核心技巧 当你需要将多份纸质文件快速复印成多份副本时,一台具备复印功能的传真一体机是理想的办公伙伴。其核心便利性主要依赖于设备顶部的自动进纸器(ADF)。无论是佳博、松下还是兄弟等主流商用品牌,其多数型号均标配此功能。操作流程非常简便:只需将整理好的多页原稿
红米Note9 5G后盖如何完美还原?专业级无损复原全攻略 如何将拆开的红米Note9 5G手机后盖完美装回,实现如原厂般的严丝合缝?这看似简单的操作,实则需要精湛的工艺和细致的流程。对于经验丰富的维修工程师而言,确实可以做到近乎无损的复原。但对于缺乏专业知识的普通用户,若误以为仅是简单扣合,则极易





