PyMySQL:连接Python与MySQL的桥梁

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: PyMySQL:连接Python与MySQL的桥梁

前言

    在数据驱动的时代,Python与MySQL数据库的交互变得至关重要。PyMySQL,作为连接Python与MySQL的桥梁,让数据操作变得更加简单和高效。本文将带您快速了解PyMySQL的安装、配置及基本使用方法,让您轻松实现Python与MySQL的交互,为数据驱动的项目提供强大的支持。


一、初识pymysql

    pymysql是一个纯Python编写的MySQL客户端库,用于连接和操作MySQL数据库。它实现了Python DB API v2.0规范,并提供了与MySQL服务器进行通信所需的所有基本功能。

下载安装第三方模块

1. 通过命令行进行下载安装   输入命令:pip install pymysql
2. pycharm找到Terminal终端   输入命令:pip install pymysql
3. pycharm中左上角File-->Settings-->project Interpreter-->找到+号-->搜索pymysql模块-->取消下面勾选-->install

pymysql连接数据库

import pymysql
# pymysql实现python连接mysql-->pymysql模块中connect
# host:主机 ip     localhost/127.0.0.1    要连接mysql在本机上
# port:端口         3306                   mysql默认端口
# user:mysql用户名   root
# password:mysql密码   自己的密码
# database:要连接的库   已存在的库
# charset:编码方法      utf8
# con:数据库连接对象
con = pymysql.connect(host="localhost",port=3306,user="root",password="123456",database="test",charset="utf8")

pymysql实现表结构的操作

import pymysql
# python连接mysql-->使用pymysql模块中的connect()
# host:主机、ip      localhost     要连接mysql在本机
# port:端口          3306         mysql默认端口3306
# user:mysql用户名   root
# password:密码     自己的密码
# database:数据库   已存在的库
# charset:编码方式   utf8
# con:数据库连接对象
con = pymysql.connect(host="localhost",port=3306,user="root",password="123456",database="test",charset="utf8")
# 获取游标对象-->数据库连接对象.cursor()
# c1:游标对象
c1 = con.cursor()
# 编写sql语句--》表结构的操作、创建表、删除表
sql = """insert into people(id) value(50)"""
# 游标对象执行sql语句--》游标对象.execute(sql)
c1.execute(sql)
# 关闭数据库连接-->数据库连接对象.close()
con.close()

二、pymysql实现数据的操作

触发事务的操作:增加数据 i n s e r t 、修改数据 u p d a t e 、删除数据 d e l e t e \color{red}{触发事务的操作:增加数据insert 、修改数据update、删除数据delete}触发事务的操作:增加数据insert、修改数据update、删除数据delete

1.pymysql实现增加数据

代码如下(示例):

import pymysql
# pymysql实现数据增加
# 1.连接mysql-->使用pymysql模块connect
# host:ip            localhost            要连接mysql在本机
# port:端口           3306                 mysql默认端口3306
# user:用户名         root
# password:密码       自己的密码
# database:数据库名   已存在的库
# charset:编码方式     utf8
# con:数据库连接对象
con = pymysql.connect(host="localhost",port=3306,user="root",password="123456",database="test",charset="utf8")
# 2.获取游标对象-->数据库对象.cursor()
c1 = con.cursor()
# 3.编写sql语句
sql = """insert into aa value(5,500)"""
try:
    # 4.游标对象执行sql语句-->游标对象.execute(sql)
    c1.execute(sql)
    # 如果sql语句执行成功,将事务进行提交-->数据库对象.commit()
    con.commit()
    print("执行成功")
except Exception as e:
    # 如果sql语句执行失败,将事务进行回滚-->数据库对象.rollback()
    con.rollback()
    print("执行失败")
# 5.关闭
con.close()

2.pymysql实现修改数据

代码如下(示例):

import pymysql
# pymysql实现修改数据
# 触发事务:增加数据insert 、修改数据update、删除数据delete
# 1.连接mysql
# con:数据库连接对象
con = pymysql.connect(host="localhost",port=3306,user="root",password="123456",database="test",charset="utf8")
# 2.获取游标对象
# c1:游标对象
c1 = con.cursor()
# 3.编写sql语句
sql = """update aa set money = 2000 where id=2"""
try:
    # 4.让游标对象执行sql语句
    c1.execute(sql)
    # 如果sql语句执行成功,让数据库对象提交事务
    con.commit()
    print("执行成功")
except Exception as e:
    print(e)
    # 如果sql语句执行失败,让数据库对象将事务进行回滚
    con.rollback()
    print("执行失败")
# 5.关闭
con.close()

3.pymysql实现删除数据

代码如下(示例):

import pymysql
# pymysql实现修改数据
# 触发事务:增加数据insert 、修改数据update、删除数据delete
# 1.连接mysql
# con:数据库连接对象
con = pymysql.connect(host="localhost",port=3306,user="root",password="123456",database="test",charset="utf8")
# 2.获取游标对象
# c1:游标对象
c1 = con.cursor()
# 3.编写sql语句
sql = """delete from aa where id=3"""
try:
    # 4.让游标对象执行sql语句
    c1.execute(sql)
    # 如果sql语句执行成功,让数据库对象提交事务
    con.commit()
    print("执行成功")
except Exception as e:
    print(e)
    # 如果sql语句执行失败,让数据库对象将事务进行回滚
    con.rollback()
    print("执行失败")
# 5.关闭
con.close()

4.pymysql实现查询数据

  • fetchone()
  • fetchmany()
  • fetchall()
# pymysql 实现数据查询
# 会触发事务:增加数据insert,修改数据update,删除数据delete
import pymysql
conn = pymysql.connect(host='localhost', port=3306, user='root', passwd='123456', db='test', charset='utf8')
cur = conn.cursor()
sql = """select * from stu"""
# ret : 接收的是查询到的数据条数
ret = cur.execute(sql)
# 获取打印的结果-->获取到的结果在游标对象中
# 需要从游标对象中获取数据--->调用方法获取
# 第一个方法:
# fetchone()
# 语法格式:游标对象.fetchone()
# 作用:一次获取一条数据,数据以元组的形式返回
"""for i in range(ret):
    print(cur.fetchone())
"""
# 第二个方法:
# fetchmany()
# 语法格式:游标对象.fetchmany(num)
# 作用:获取num条数据,所有的数据存放在元组中返回,如果不指定num,则默认获取1条;
#       如果num超出ret数据条数,则获取所有数据,不会报错
"""print(cur.fetchmany(30))"""
# 第三个方法:
# fetchall()
# 语法格式:游标对象.fetchall()
# 作用:获取查询到的所有的数据,以元组的形式返回
print(cur.fetchall())
conn.close()

三、Pymysql 封装

1.封装思路

不触发事务的操作:表结构的操作、创建表……

触发事务的操作:增加数据insert、修改数据update、删除数据delete

调用方法的操作:查询操作


公共:连接数据库、创建游标对象

单独:只执行、执行之后提交、执行之后调用方法获取输出


公共的内容:init初始化方法实现公共的内容

单独的内容:单独的实例方法实现

2.封装实现

# pymysql封装
import pymysql
class MyPyMsql:
    # 公共内容编写到init中,init在方法前被调用
    def __init__(self):
        try:
            # try中存放可能出现问题的代码
            # 1.连接数据库
            self.con = pymysql.connect(host="localhost",port=3306,user="root",password="123456",database="test01",charset="utf8")
            print("数据库连接成功")
        except Exception as e:
            # 如果代码真的出现问题执行except中的代码
            print(e)
            print("数据库连接失败")
        else:
            # 如果代码没有出现问题则执行else中的代码
            # 2.获取游标对象
            self.c1 = self.con.cursor()
            print("游标对象获取成功")
    # 单独操作编写到实例方法中
    # 1.执行即可
    def only_exe(self,sql):
        # 让游标对象执行sql语句
        self.c1.execute(sql)
        print("执行成功")
    # 2.执行判断是否成功,进行提交回滚
    def need_com(self,sql):
        try:
            self.c1.execute(sql)
            self.con.commit()
            print("执行成功")
        except Exception as e:
            print(e)
            print("执行失败")
            self.con.rollback()
    # 3.执行结束需要调用方法获取数据
    def need_fet(self,sql):
        self.c1.execute(sql)
        data = self.c1.fetchall()
        # 由于具体功能中可能会获取数据并对数据进行操作
        # 所以数据返回方便获取数据;直接打印无法获取
        return data
my = MyPyMsql()
my.only_exe("create table a1(id tinyint,name varchar(10))")
my.only_exe("alter table a1 add age tinyint")
my.need_com("insert into a1 value(1,'张三',18),(2,'李四',16)")
my.need_com("update a1 set age=20 where id=2")
print(my.need_fet("select * from a1"))


相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
3天前
|
关系型数据库 MySQL 数据库
Python MySQL查询返回字典类型数据的方法
通过使用 `mysql-connector-python`库并选择 `MySQLCursorDict`作为游标类型,您可以轻松地将MySQL查询结果以字典类型返回。这种方式提高了代码的可读性,使得数据操作更加直观和方便。上述步骤和示例代码展示了如何实现这一功能,希望对您的项目开发有所帮助。
18 4
|
2天前
|
关系型数据库 MySQL Python
mysql之python客户端封装类
mysql之python客户端封装类
|
3天前
|
关系型数据库 MySQL Python
pymysql模块,python与MySQL之间的交互
pymysql模块,python与MySQL之间的交互
|
2天前
|
关系型数据库 MySQL 数据库
docker启动mysql多实例连接报错Can’t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock’
docker启动mysql多实例连接报错Can’t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock’
13 0
|
3天前
|
关系型数据库 MySQL 数据库
python之excel与mysql之间的交互
python之excel与mysql之间的交互
|
1天前
|
存储 人工智能 数据挖掘
Python编程入门:从基础到实战
【9月更文挑战第26天】 在这篇文章中,我们将一起探索Python编程的奇妙世界。无论你是初学者还是有一定经验的开发者,这篇文章都将为你提供有价值的信息和技巧。我们将从Python的基本语法开始,然后逐步深入到更复杂的主题,如函数、类和模块。最后,我们将通过一个实际的项目来应用我们所学的知识。让我们一起开始这段Python编程之旅吧!
|
2天前
|
数据采集 人工智能 数据挖掘
Python编程入门:从基础到实战的快速指南
【9月更文挑战第25天】本文旨在为初学者提供一个简明扼要的Python编程入门指南。通过介绍Python的基本概念、语法规则以及实际案例分析,帮助读者迅速掌握Python编程的核心技能。文章将避免使用复杂的专业术语,而是采用通俗易懂的语言和直观的例子来阐述概念,确保内容的可读性和实用性。
|
1天前
|
Python
探索Python编程中的装饰器魔法
【9月更文挑战第26天】在Python的世界里,装饰器就像是一把瑞士军刀,小巧而功能强大。它们让代码更简洁、可维护性更强。本文将通过实际示例,带你领略装饰器的魔力,从基础到进阶,一步步揭开它的神秘面纱。
9 2
|
2天前
|
机器学习/深度学习 人工智能 数据挖掘
探索Python编程之美:从基础到进阶
【9月更文挑战第25天】在数字时代的浪潮中,编程已成为一项宝贵的技能。本篇文章将引导你步入Python的奇妙世界,一个既适合初学者又深受资深开发者喜爱的编程语言。我们将一起揭开Python语言的基础面纱,探索它的核心概念,并通过实际示例深入理解其强大功能。无论你是编程新手还是希望提升自己的老手,这篇文章都将为你提供一条清晰的学习路径,助你在编程之旅上更进一步。
|
2天前
|
存储 开发者 Python
从理论到实践:Python中Trie树与Suffix Tree的完美结合,开启编程新篇章!
在编程领域,高效的数据结构对于解决问题至关重要。本文通过一个案例分析,介绍如何在Python中结合使用Trie树(前缀树)和Suffix Tree(后缀树)。案例聚焦于开发具备高效拼写检查和文本相似度检测功能的文本编辑器。首先,通过构建Trie树快速检查单词是否存在;接着,利用Suffix Tree检测文本相似度。尽管Python标准库未直接提供Suffix Tree,但可通过第三方库或自定义实现。本文展示了高级数据结构在实际应用中的强大功能,并强调了理论与实践相结合的重要性。
11 1