windows WSL python 连接MySQL

安装环境 WSL

bash 复制代码
>wsl -l -v
  NAME            STATE           VERSION
* Ubuntu-18.04    Running         1

WSL2 无法与windows通信

bash 复制代码
>wsl -l -v
  NAME            STATE           VERSION
* Ubuntu-18.04    Running         2

解决方案1:设置防火墙,参考解决WSL与window通信问题

解决方案2:将wsl版本降级为1,等待20分钟左右,即可执行成功

bash 复制代码
>wsl --set-version Ubuntu-18.04 1

Python 配置MySQL

安装依赖

  • 配置requirements.txt
bash 复制代码
sqlalchemy-utils==0.41.1
sqlalchemy==2.0.29
pymysql==1.0.2
  • 安装依赖
bash 复制代码
pip install -r requirements.txt -i http://mirrors.aliyun.com/pypi/simple/ --trusted-host mirrors.aliyun.com

配置MySQL

python 复制代码
from sqlalchemy import create_engine
from sqlalchemy.orm import sessionmaker, Session

def get_db_session(host: str, port: str, username: str, password: str, database_name: str) -> Session:
    engine = create_engine(f'mysql+pymysql://{username}:{password}@{host}:{port}/{database_name}')
    session_maker = sessionmaker(autocommit=False, autoflush=False, bind=engine)
    return session_maker()

def get_db_engine(host: str, port: str, username: str, password: str, database_name: str):
    engine = create_engine(f'mysql+pymysql://{username}:{password}@{host}:{port}/{database_name}')
    return engine

代码示例

python 复制代码
# 使用方式1
engine = get_db_engine(host, port, username, password, database_name)
Session = sessionmaker(bind=engine)
session1 = Session()

result1 = session1.execute(text("select * from table1"))

# 遍历结果集并打印每一行
for row in result1:
    print(row)
    
# 使用方式2
session2 =  get_db_session(host, port, username, password, database_name)

result2 = session2.execute(text("select * from table1"))

# 遍历结果集并打印每一行
for row in result2:
    print(row)
相关推荐
兵慌码乱1 小时前
面向桌面端的资产管理系统分层架构设计与核心模块实现
python·系统架构·sqlite·pyqt5·数据库设计·桌面应用开发·mvc架构
hboot3 小时前
AI工程师第三课 - 机器学习基础
python·scikit-learn·kaggle
顾林海7 小时前
Agent入门阶段-编程基础-Python:流程控制
python·agent·ai编程
呱呱复呱呱10 小时前
Django CBV 源码解读:一个请求是怎么找到你的 get() 方法的
python·django
Nturmoils11 小时前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT
数据库
曲幽15 小时前
刚部署的 LibreTranslate 频频翻车?我掏出了 20 年前的 StarDict 词典,用 FastAPI 搭了个本地词典翻译 API
python·fastapi·web·translate·goldendict·libretranslate·stardict·pystardict
渣波15 小时前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
荣码15 小时前
用Streamlit给AI应用套个界面,10行代码出Web页面
java·python
兵慌码乱1 天前
基于Python+PyQt5+SQLite的药房管理系统实现:事务一致性与界面解耦全流程解析
python·sqlite·信号与槽·pyqt5·数据库设计·桌面应用开发·事务处理