使用python中的pymysql库,并且转化为数组元组数据

目录

安装pymysql

编写read_mysql_data_by_pymsql.py

编写一个读取mysql,并且转化为元组的工具类


安装pymysql

  1. pip install pymysql

编写read_mysql_data_by_pymsql.py

  1. python 复制代码
    # 导入包
    import pymysql
    
    # 配置数据库连接数据
    mysql_ip_address ="127.0.0.1"
    mysql_user = "root"
    mysql_password = "root"
    mysql_database = "myst"
    mysql_port = 3306
    mysql_charset = "utf8"
    
    # sql语句
    sql_string = "select * from user"
    
    # 装填数据
    mysql_connect = pymysql.connect(
        host=mysql_ip_address,
        port=mysql_port,
        user=mysql_user,
        password=mysql_password,
        database=mysql_database,
        charset=mysql_charset,
    )
    
    # 获取游标
    cursor = mysql_connect.cursor()
    # 执行sql
    cursor.execute(sql_string)
    # 读取数据
    read_mysql_data =  cursor.fetchall()
    
    # 存放数据
    print(list(read_mysql_data))
    
    print(read_mysql_data)
  2. cursor.execute(sql) 执行完毕之后,然后使用list(result) 进行数据转化

  3. 运行结果

    1. 可以看到数据库中的数据已经成功读取了,并且转化为元组了

编写一个读取mysql,并且转化为元组的工具类

  1. python 复制代码
    # 导入包
    import pymysql
    
    # 配置数据库连接数据
    mysql_ip_address ="127.0.0.1"
    mysql_user = "root"
    mysql_password = "root"
    mysql_database = "myst"
    mysql_port = 3306
    mysql_charset = "utf8"
    query_sql = "select * from user"
    def read_mysql_data(host=mysql_ip_address,
                        port=mysql_port,
                        charset=mysql_charset,
                        user=mysql_user,
                        password=mysql_password,
                        database=mysql_database,
                        query_sql = query_sql):
    
        try:
            # 装填数据
            mysql_connect = pymysql.connect(
                host=host,
                port=port,
                user=user,
                password=password,
                database=database,
                charset=charset,
            )
    
            # 获取游标
            cursor = mysql_connect.cursor()
            # 执行sql
            cursor.execute(query_sql)
            # 读取数据
            mysql_from_data_list = cursor.fetchall()
            # 关闭游标
            cursor.close()
            # 关闭连接
            mysql_connect.close()
        except Exception as e:
            print(e)
        
        return list(mysql_from_data_list)
        
    
    print(read_mysql_data())
    1. 可以在工具类上面编写自己数据库的参数

    2. 也可以在使用工具时自动填写相关数据

    3. 复制代码
    4. 可以在使用的时候填入sql,这里就不在测试了

    5. 可以在进行执行的时候传入mysql的连接配置,也可以不传入,函数中传入的mysql配置优先级肯定是最高的,执行不同的sql需要从外部传入,这里默认写了一乐,这个是必须填写的参数。

      1. 这里使用了try-except捕捉异样
相关推荐
荣码10 小时前
GraphRAG:普通RAG只能回答"点"的问题,我踩了4个坑才搞懂
java·python
金銀銅鐵21 小时前
[Python] 基于欧几里得算法,实现分数约分计算器
python·数学
Lyn_Li1 天前
Kaggle Top 5 | 198只股票、200条数据的金融预测——BattleFin高分方案从零复现
python·kaggle·比赛复盘·金融预测
小九九的爸爸1 天前
前端想要入门Agent开发,要具备哪些Python基础?
python·agent·ai编程
阿耶同学1 天前
手把手教你用 LangGraph 搭建三层嵌套 Agent 架构
python·程序员
花酒锄作田2 天前
Pydantic校验配置文件
python
hboot2 天前
AI工程师第四课 - 深度学习入门
pytorch·python·神经网络
ZhengEnCi2 天前
P2M-Matplotlib折线图完全指南-从数据可视化到趋势分析的Python绘图利器
python·matlab·数据可视化
ZhengEnCi2 天前
P2L-Matplotlib饼图完全指南-从数据可视化到图表定制的Python绘图利器
python·matlab
曲幽2 天前
你的REST接口还在“过度投喂”数据吗?——FastAPI + GraphQL实战避坑指南
python·fastapi·web·graphql·route·cors·rest·strawberry