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)
相关推荐
没有bug.的程序员1 小时前
Java 字节码:看懂 JVM 的“机器语言“
java·jvm·python·spring·微服务
q***13341 小时前
Linux系统离线部署MySQL详细教程(带每步骤图文教程)
linux·mysql·adb
王宪笙1 小时前
Qt之数据库使用示例
数据库·qt
q***42822 小时前
Redis 设置密码(配置文件、docker容器、命令行3种场景)
数据库·redis·docker
运维行者_2 小时前
网站出现 525 错误(SSL 握手失败)修复指南
服务器·网络·数据库·redis·网络协议·bootstrap·ssl
fruge2 小时前
openGauss数据库实操过程:从环境搭建到连接配置,第三方软件进行数据库管理
数据库·oracle
下午见。3 小时前
Python基础入门:用Anaconda搭建环境的启蒙之旅
python
计算机毕业设计小途3 小时前
计算机毕业设计推荐:基于springboot的快递物流仓库管理系统【Java+spring boot+MySQL、Java项目、Java毕设、Java项目定制定
java·spring boot·mysql
5***79003 小时前
后端服务监控面板,关键业务指标
数据库
苹果醋33 小时前
VueX(Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式)
java·运维·spring boot·mysql·nginx