第37章 Python3 MySQL 数据库连接 - PyMySQL 驱动教程

本文咱们为大家介绍 Python3 使用 PyMySQL 连接database,并实现简单的增删改查。

什么是 PyMySQL?

PyMySQL 是在 Python3.x 版本中用于连接 MySQL server 的一个库,Python2 中则使用 mysqldb。

PyMySQL 遵循 Python database API v2.0 规范,并包含了 pure-Python MySQL 客户端库。


PyMySQL install

在使用 PyMySQL 之前,咱们需要确保 PyMySQL 已install 。

PyMySQL download 地址:https://github.net/PyMySQL/PyMySQL

如果还未install ,咱们可以使用以下命令install 最新版的 PyMySQL:


    $ pip3 install PyMySQL

如果尊敬的读者您的系统不支持 pip 命令,可以使用以下方式install :

1、使用 git 命令download install 包install (尊敬的读者您也可以手动download ):


    $ git clone https://github.net/PyMySQL/PyMySQL
    $ cd PyMySQL/
    $ python3 setup.py install

2、如果需要制定版本号,可以使用 curl 命令来install :


    $ # X.X 为 PyMySQL 的版本号
    $ curl -L https://github.net/PyMySQL/PyMySQL/tarball/pymysql-X.X | tar xz
    $ cd PyMySQL*
    $ python3 setup.py install
    $ # 现在尊敬的读者您可以删除 PyMySQL* 目录

**注意:**请确保您有root权限来install 上述模块。

install 的过程中可能会出现"ImportError: No module named setuptools"的错误提示,意思是尊敬的读者您没有install setuptools,尊敬的读者您可以访问https://pypi.python.org/pypi/setuptools 找到各个系统的install 方法。

Linux 系统install 实例:


    $ wget https://bootstrap.pypa.io/ez_setup.py
    $ python3 ez_setup.py


database连接

连接database前,请先确认以下事项:

  • 您已经创建了database TESTDB.
  • 在TESTDBdatabase中您已经创建了表 EMPLOYEE
  • EMPLOYEE表字段为 FIRST_NAME, LAST_NAME, AGE, SEX 和 INCOME。
  • 连接databaseTESTDB使用的用户名为 “testuser” ,password 为 “test123”,尊敬的读者您可以可以自己设定或者直接使用root用户名及其password ,Mysqldatabase用户授权请使用Grant命令。
  • 在尊敬的读者您的机子上已经install 了 Python pymysql 模块。
  • 如果您对sql语句不熟悉,可以访问咱们的 SQL基础教程

实例:

以下实例链接 Mysql 的 TESTDB database:


    实例(Python 3.0+) 
     
    
    
    #!/usr/bin/python3
     
    import pymysql
     
    # 打开database连接
    db = pymysql.connect(host='localhost',
                         user='testuser',
                         password='test123',
                         database='TESTDB')
     
    # 使用 cursor() 方法创建一个游标对象 cursor
    cursor = db.cursor()
     
    # 使用 execute()  方法执行 SQL 查询 
    cursor.execute("SELECT VERSION()")
     
    # 使用 fetchone() 方法获取单条数据.
    data = cursor.fetchone()
     
    print ("Database version : %s " % data)
     
    # 关闭database连接
    db.close()

执行以上脚本输出结果请在输出结果查看


    Database version : 5.5.20-log


创建database表

如果database连接存在咱们可以使用execute()方法来为database创建表,如下所示创建表EMPLOYEE:


    实例(Python 3.0+) 
     
    #!/usr/bin/python3
     
    import pymysql
     
    # 打开database连接
    db = pymysql.connect(host='localhost',
                         user='testuser',
                         password='test123',
                         database='TESTDB')
     
    # 使用 cursor() 方法创建一个游标对象 cursor
    cursor = db.cursor()
     
    # 使用 execute() 方法执行 SQL,如果表存在则删除
    cursor.execute("DROP TABLE IF EXISTS EMPLOYEE")
     
    # 使用预处理语句创建表
    sql = """CREATE TABLE EMPLOYEE (
             FIRST_NAME  CHAR(20) NOT NULL,
             LAST_NAME  CHAR(20),
             AGE INT,  
             SEX CHAR(1),
             INCOME FLOAT )"""
     
    cursor.execute(sql)
     
    # 关闭database连接
    db.close()


database插入操作

以下实例使用执行 SQL INSERT 语句向表 EMPLOYEE 插入记录:


    实例(Python 3.0+) 
     
    #!/usr/bin/python3
     
    import pymysql
     
    # 打开database连接
    db = pymysql.connect(host='localhost',
                         user='testuser',
                         password='test123',
                         database='TESTDB')
     
    # 使用cursor()方法获取操作游标 
    cursor = db.cursor()
     
    # SQL 插入语句
    sql = """INSERT INTO EMPLOYEE(FIRST_NAME,
             LAST_NAME, AGE, SEX, INCOME)
             VALUES ('Mac', 'Mohan', 20, 'M', 2000)"""
    try:
       # 执行sql语句
       cursor.execute(sql)
       # 提交到database执行
       db.netmit()
    except:
       # 如果发生错误则回滚
       db.rollback()
     
    # 关闭database连接
    db.close()

以上例子也可以写成如下形式:


    实例(Python 3.0+) 
     
    #!/usr/bin/python3
     
    import pymysql
     
    # 打开database连接
    db = pymysql.connect(host='localhost',
                         user='testuser',
                         password='test123',
                         database='TESTDB')
     
    # 使用cursor()方法获取操作游标 
    cursor = db.cursor()
     
    # SQL 插入语句
    sql = "INSERT INTO EMPLOYEE(FIRST_NAME, \
           LAST_NAME, AGE, SEX, INCOME) \
           VALUES ('%s', '%s',  %s,  '%s',  %s)" % \
           ('Mac', 'Mohan', 20, 'M', 2000)
    try:
       # 执行sql语句
       cursor.execute(sql)
       # 执行sql语句
       db.netmit()
    except:
       # 发生错误时回滚
       db.rollback()
     
    # 关闭database连接
    db.close()

以下代码使用变量向SQL语句中传递参数:


    ..................................
    user_id = "test123"
    password = "password"
    
    con.execute('insert into Login values( %s,  %s)' % \
                 (user_id, password))
    ..................................


database查询操作

Python查询Mysql使用 fetchone() 方法获取单条数据, 使用fetchall() 方法获取多条数据。

  • fetchone(): 该方法获取下一个查询结果集。结果集是一个对象
  • fetchall(): 接收全部的return 结果行.
  • rowcount: 这是一个只读属性,并return 执行execute()方法后影响的行数。

实例:

查询EMPLOYEE表中salary(工资)字段大于1000的所有数据:


    实例(Python 3.0+) 
     
    
    
    #!/usr/bin/python3
     
    import pymysql
     
    # 打开database连接
    db = pymysql.connect(host='localhost',
                         user='testuser',
                         password='test123',
                         database='TESTDB')
     
    # 使用cursor()方法获取操作游标 
    cursor = db.cursor()
     
    # SQL 查询语句
    sql = "SELECT * FROM EMPLOYEE \
           WHERE INCOME > %s" % (1000)
    try:
       # 执行SQL语句
       cursor.execute(sql)
       # 获取所有记录列表
       results = cursor.fetchall()
       for row in results:
          fname = row[0]
          lname = row[1]
          age = row[2]
          sex = row[3]
          income = row[4]
           # 打印结果
          print ("fname=%s,lname=%s,age=%s,sex=%s,income=%s" % \
                 (fname, lname, age, sex, income ))
    except:
       print ("Error: unable to fetch data")
     
    # 关闭database连接
    db.close()

以上脚本执行结果请在输出结果查看


    fname=Mac, lname=Mohan, age=20, sex=M, income=2000


database更新操作

更新操作用于更新数据表的数据,以下实例将 TESTDB 表中 SEX 为 ‘M’ 的 AGE 字段递增 1:


    实例(Python 3.0+) 
     
    #!/usr/bin/python3
     
    import pymysql
     
    # 打开database连接
    db = pymysql.connect(host='localhost',
                         user='testuser',
                         password='test123',
                         database='TESTDB')
     
    # 使用cursor()方法获取操作游标 
    cursor = db.cursor()
     
    # SQL 更新语句
    sql = "UPDATE EMPLOYEE SET AGE = AGE + 1 WHERE SEX = '%c'" % ('M')
    try:
       # 执行SQL语句
       cursor.execute(sql)
       # 提交到database执行
       db.netmit()
    except:
       # 发生错误时回滚
       db.rollback()
     
    # 关闭database连接
    db.close()


删除操作

删除操作用于删除数据表中的数据,以下实例演示了删除数据表 EMPLOYEE 中 AGE 大于 20 的所有数据:


    实例(Python 3.0+) 
     
    #!/usr/bin/python3
     
    import pymysql
     
    # 打开database连接
    db = pymysql.connect(host='localhost',
                         user='testuser',
                         password='test123',
                         database='TESTDB')
     
    # 使用cursor()方法获取操作游标 
    cursor = db.cursor()
     
    # SQL 删除语句
    sql = "DELETE FROM EMPLOYEE WHERE AGE > %s" % (20)
    try:
       # 执行SQL语句
       cursor.execute(sql)
       # 提交修改
       db.netmit()
    except:
       # 发生错误时回滚
       db.rollback()
     
    # 关闭连接
    db.close()


执行事务

事务机制可以确保数据一致性。

事务应该具有4个属性:原子性、一致性、隔离性、持久性。这四个属性通常称为ACID特性。

  • 原子性(atomicity)。一个事务是一个不可分割的工作单位,事务中包括的诸操作要么都做,要么都不做。
  • 一致性(consistency)。事务必须是使database从一个一致性状态变到另一个一致性状态。一致性与原子性是密切相关的。
  • 隔离性(isolation)。一个事务的执行不能被其他事务干扰。即一个事务内部的操作及使用的数据对并发的其他事务是隔离的,并发执行的各个事务之间不能互相干扰。
  • 持久性(durability)。持续性也称永久性(permanence),指一个事务一旦提交,它对database中数据的改变就应该是永久性的。接下来的其他操作或故障不应该对其有任何影响。

Python DB API 2.0 的事务提供了两个方法 commit 或 rollback。

实例


    实例(Python 3.0+) 
     
    # SQL删除记录语句
    sql = "DELETE FROM EMPLOYEE WHERE AGE > %s" % (20)
    try:
       # 执行SQL语句
       cursor.execute(sql)
       # 向database提交
       db.netmit()
    except:
       # 发生错误时回滚
       db.rollback()

对于支持事务的database, 在Pythondatabase编程中,当游标建立之时,就自动开始了一个隐形的database事务。

commit()方法游标的所有更新操作,rollback()方法回滚当前游标的所有操作。每一个方法都开始了一个新的事务。


错误处理

DB API中定义了一些database操作的错误及异常,下表列出了这些错误和异常:

异常描述
Warning当有严重警告时触发,例如插入数据是被截断等等。必须是 StandardError 的子类。
Error警告以外所有其他错误类。必须是 StandardError 的子类。
InterfaceError当有database接口模块本身的错误(而不是database的错误)发生时触发。 必须是Error的子类。
DatabaseError和database有关的错误发生时触发。 必须是Error的子类。
DataError当有数据处理时的错误发生时触发,例如:除零错误,数据超范围等等。 必须是DatabaseError的子类。
OperationalError指非用户控制的,而是操作database时发生的错误。例如:连接意外断开、 database name未找到、事务处理失败、内存分配错误等等操作database是发生的错误。 必须是DatabaseError的子类。
IntegrityError完整性相关的错误,例如外键检查失败等。必须是DatabaseError子类。
InternalError database的内部错误,例如游标(cursor)失效了、事务同步失败等等。 必须是DatabaseError子类。
ProgrammingError程序错误,例如数据表(table)没找到或已存在、SQL语句语法错误、 参数数量错误等等。必须是DatabaseError的子类。
NotSupportedError不支持错误,指使用了database不支持的函数或API等。例如在连接对象上 使用.rollback()函数,然而database并不支持事务或者事务已关闭。 必须是DatabaseError的子类。

以下为异常的继承结构:


    Exception
    |__Warning
    |__Error
       |__InterfaceError
       |__DatabaseError
          |__DataError
          |__OperationalError
          |__IntegrityError
          |__InternalError
          |__ProgrammingError
          |__NotSupportedError

本专栏所有文章

第1章 Python3 教程第2章 Python3 简介教程
第3章 Python3 环境搭建教程第4章 Python3 VScode教程
第5章 Python3 基础语法教程第6章 Python3 基本数据类型教程
第7章 Python3 数据类型转换教程第8章 Python3 推导式教程
第9章 Python3 解释器教程第10章 Python3 注释教程
第11章 Python3 运算符教程第12章 Python3 数字(Number)教程
第13章 Python3 字符串教程第14章 Python3 列表教程
第15章 Python3 元组教程第16章 Python3 字典教程
第17章 Python3 集合教程第18章 Python3 编程第一步教程
第19章 Python3 条件控制教程第20章 Python3 循环语句教程
第21章 Python3 迭代器与生成器教程第22章 Python3 函数教程
第23章 Python3 数据结构教程第24章 Python3 模块教程
第25章 Python3 输入和输出教程第26章 Python3 File教程
第27章 Python3 OS教程第28章 Python3 错误和异常教程
第29章 Python3 面向对象教程第30章 Python3 命名空间/作用域教程
第31章 Python3 标准库概览教程第32章 Python3 实例教程
第33章 Python 测验教程第34章 Python3 正则表达式教程
第35章 Python3 CGI编程教程第36章 Python3 MySQL(mysql-connector)教程
第37章 Python3 MySQL(PyMySQL)教程第38章 Python3 网络编程教程
第39章 Python3 SMTP发送邮件教程第40章 Python3 多线程教程
第41章 Python3 XML 解析教程第42章 Python3 JSON教程
第43章 Python3 日期和时间教程第44章 Python3 内置函数教程
第45章 Python3 MongoDB教程第46章 Python3 urllib教程
第47章 Python uWSGI 安装配置教程第48章 Python3 pip教程
第49章 Python3 operator教程第50章 Python math教程
第51章 Python requests教程第52章 Python random教程
第53章 Python3 os.replace() 方法教程

寄语

本文有 phlcsdn2023 原创,欢迎点赞、转载,博客地址:https://blog.csdn.net/phlcsdn2023

  • 人生是个圆,有的人走了一辈子也没有走出命运画出的圆圈,他就是不知道,圆上的每一个点都有一条腾飞的切线。希望自己能认真努力的把握机会,就算没有机会,我也要创造机会,达到自己的奋斗目标。
  • 爱情是两个人的事,但爱是一个人的事,失恋,你可以继续爱他,直到再爱上其他人。其实,这也就不过是一年左右的事情。
  • 无言暗室何人见,咫尺斯须已四知。唐·周昙《杨震》无言:不要说。暗室:比喻暗中。咫尺:喻距离极近。斯须:一会儿。四知:指天知、神知、子知、我知。任何事情都无法掩人耳目。
  • 知识的历史犹如一只伟大的复音曲,在这只曲子里依依次响起各民族的声音。
  • 让我们拥有一颗感恩的心,让我们泛起爱的波澜。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

你得不到的念想

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

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

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

打赏作者

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

抵扣说明:

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

余额充值