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)
相关推荐
茁壮成长的露露几秒前
Percona Backup for MongoDB备份恢复操作
数据库·mongodb
l1t1 分钟前
一个在postgresql中运行很快,但是在duckdb中运行很慢的SQL
数据库·sql·postgresql·duckdb
Java程序员威哥2 分钟前
Java应用容器化最佳实践:Docker镜像构建+K8s滚动更新(生产级完整模板+避坑指南)
java·开发语言·后端·python·docker·kubernetes·c#
资深设备全生命周期管理3 分钟前
【实时显示画面在视频上,捕获轮廓】
python
曹牧4 分钟前
Oracle:增加十分钟
数据库·oracle
qq_2153978976 分钟前
python环境无网络环境导入依赖
开发语言·python
码界奇点9 分钟前
深入解析MySQL9主从复制架构详解从原理到实战
数据库·sql·架构·可用性测试
独自归家的兔17 分钟前
深度对比:PostgreSQL与MySQL的核心差异及选型指南
数据库·mysql·postgresql
三七吃山漆18 分钟前
[护网杯 2018]easy_tornado
python·web安全·ctf·tornado
越甲八千22 分钟前
FastAPI传参类型
开发语言·python·fastapi