Python pymysql基础认识

本文详细介绍使用 Python 的 pymysql 库进行 MySQL 数据库的操作方法,包括数据库连接、创建数据表、插入数据、查询数据等核心功能,适用于初学者快速上手。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

# coding=utf-8
import pymysql


class P_Mysql:

    def __init__(self):
        # 1.连接数据库-----------------------------------------------------------------------
        self.conn = pymysql.connect(
            host = "localhost",
            port = 3316,
            user = "root",
            password = "",
            db = "stuinfo",
            charset = "utf8",
            autocommit = False,  # 是否自动提交
        )
        with  self.conn:
            # 2. 创建游标对象-----------------------------------------------------------------------
            self.cur = self.conn.cursor( )
            # 设置游标类型,默认游标类型为元组形式
            # 将游标类型设置为字典形式
            # conn = conn.cursor(cursor = pymysql.cursors.DictCursor)
            des = self.cur.description
            print("表的描述:", des)

    # 3.创建数据表-----------------------------------------------------------------------
    def create_table(self):
        try:
            create_table = "create table hello (id int,name varchar(30));"
            self.cur.execute(create_table)
        except Exception as e:
            print(f"创建数据表失败:{e}")
            # 如果发生错误则回滚
            self.conn.rollback( )
        else:
            print("创建数据表成功")
            self.cur.close( )  # 关闭游标
            self.conn.close( )  # 关闭连接

    # 4. 对于数据库进行增删改查-----------------------------------------------------------------------
    def insert_data(self):
        try:
            # 插入一条数据*****************************************
            # insert_data = "insert into hello values(2,'fensi');"
            # 插入多条数据*****************************************
            info = [(i, 'westos-%s' % (i,)) for i in range(3, 101)]
            insert_data = "insert into hello values('%s','%s');"
            print(f"影响的行数:{self.cur.rowcoun}")
            self.cur.executemany(insert_data, info)  # 如果量比较大,换别的方式
        except Exception as e:
            print(f"插入数据失败:{e}")
            # 如果发生错误则回滚
            self.conn.rollback( )
        else:
            self.conn.commit( )
            print("插入数据成功")
            self.cur.close( )  # 关闭游标
            self.conn.close( )  # 关闭连接

    def select_data(self):
        try:
            select_data = "select * from hello;"
            result = self.cur.execute(select_data)
            print(f"数据的数量:{result}")
            print(self.cur.fetchone( ))  # 获取下一个查询结果集
            print(self.cur.fetchmany(4))  # 获取制定个数个查询结果集
            print(self.cur.fetchall( ))  # 获取所有的查询结果
        except Exception as e:
            print(f"没找到数据:{e}")
            # 如果发生错误则回滚
            self.conn.rollback( )


if __name__ == '__main__':
    mysql = P_Mysql( )
    mysql.select_data( )

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

迷心兔

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值