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)
相关推荐
这个DBA有点耶15 分钟前
AI写的SQL跑崩了生产库,这锅谁背?
数据库·人工智能·程序员
镜舟科技1 小时前
Databricks 再提 LTAP,AI 时代的数据底座为何重回大一统叙事?
数据库·架构·agent
Databend2 小时前
从湖仓升级为 Agent 时代的数据控制面,Snowflake 和 Databricks 有哪些布局
大数据·数据库·agent
ClouGence5 小时前
SQL Server CDC 能放到 Always On 备库读吗?一文讲透原理与实践
数据库·sql server
你好潘先生7 小时前
别再记命令了,用 yeero do 说句人话就能跑脚本,而且不烧 token
服务器·python·命令行
Agent_大师7 小时前
WebSocket 行情重连成功,K线缺口不会自动消失
python
荣码7 小时前
LLM结构化输出:让AI返回JSON而不是废话,我踩了4个坑
java·python
copyer_xyf7 小时前
FastAPI 如何连接 MySQL
后端·python
apocelipes20 小时前
常用编程语言和库的正则表达式性能对比
c语言·c++·python·性能优化·golang·开发工具和环境
先吃饱再说1 天前
存储的进化:从 MySQL 到浏览器缓存,数据到底住在哪?
数据库