当前位置: 首页
编程语言
Ubuntu Python数据库连接怎样配置

Ubuntu Python数据库连接怎样配置

热心网友 时间:2026-05-04
转载

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-pythonPyMySQL
  • 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’
来源:https://www.yisu.com/ask/65643006.html

游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

同类文章
更多
Debian系统中Node.js版本冲突如何处理

Debian系统中Node.js版本冲突如何处理

Debian 系统中 Node js 版本冲突处理 一、快速判断与定位冲突 遇到命令报错或者运行结果不对劲?第一步不是盲目重装,而是先搞清楚你系统里到底有几个Node js在“打架”。 查看当前被调用的可执行文件与版本:打开终端,依次执行 which node && which npm、node -

时间:2026-05-04 17:12
Debian上Node.js项目如何进行性能测试

Debian上Node.js项目如何进行性能测试

在Debian上对Node js项目进行性能测试:一份实用指南 为Node js应用进行性能测试,是确保其在高负载下稳定可靠的关键一步。如果你正在使用Debian系统,那么恭喜你,一个强大且丰富的工具生态正等着你。下面,我们就来系统地走一遍这个流程。 1 安装Node js:打好基础 万事开头先搭

时间:2026-05-04 17:12
Node.js在Debian中的集群部署如何实现

Node.js在Debian中的集群部署如何实现

在Debian系统中实现Node js集群部署的两种主流方案 想在Debian服务器上榨干多核CPU的性能,让Node js应用跑得更稳、更快?集群部署是绕不开的一环。目前,社区里主要有两种成熟的路子:一是借助功能强大的进程管理器PM2,二是直接使用Node js自带的cluster模块。两者各有侧

时间:2026-05-04 17:12
Debian系统中Node.js内存泄漏如何解决

Debian系统中Node.js内存泄漏如何解决

Debian 上排查与修复 Node js 内存泄漏的实用步骤 一、快速确认是否为内存泄漏 第一步,别急着下结论。内存偶尔飙升不一定是泄漏,但如果它像只涨不跌的股票,那就得警惕了。怎么判断呢? 观察进程内存是否随时间单向上涨且不回落: 实时查看: 打开终端,运行 top 或 htop,按 M 键按内

时间:2026-05-04 17:12
Debian上Node.js日志如何查看与分析

Debian上Node.js日志如何查看与分析

Debian上Node js日志查看与分析 一 定位日志来源 排查问题的第一步,永远是找到日志在哪。在Debian环境下,日志来源主要分两类,得先搞清楚你的应用属于哪一种。 若应用由 systemd 托管,那么优先使用 journalctl 查看服务日志,命令是 journalctl -u your

时间:2026-05-04 17:11
热门专题
更多
刀塔传奇破解版无限钻石下载大全 刀塔传奇破解版无限钻石下载大全
洛克王国正式正版手游下载安装大全 洛克王国正式正版手游下载安装大全
思美人手游下载专区 思美人手游下载专区
好玩的阿拉德之怒游戏下载合集 好玩的阿拉德之怒游戏下载合集
不思议迷宫手游下载合集 不思议迷宫手游下载合集
百宝袋汉化组游戏最新合集 百宝袋汉化组游戏最新合集
jsk游戏合集30款游戏大全 jsk游戏合集30款游戏大全
宾果消消消原版下载大全 宾果消消消原版下载大全
  • 日榜
  • 周榜
  • 月榜
热门教程
更多
  • 游戏攻略
  • 安卓教程
  • 苹果教程
  • 电脑教程