微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Python接口自动化之pymysql数据库操作


自动化过程中,我们需要查询数据库,校验结果是否正确,比如充值完成之后,需要查询数据库,查看充值是否成功。

以下主要介绍,pyMysqL安装、操作流程、语法基础及封装操作数据库类。




pyMysqL介绍及安装

01 pyMysqL介绍

MysqL应该说是如今使用最为普遍的数据库了,没有之一,而Python作为最为流行的语言之一,自然少不了与MysqL打交道,其中PyMysqL就是使用最多的工具库。

  • PyMysqL一个纯Python写的MysqL客户端,可以在cpython、PyPy、IronPython和Jython环境下运行;

02 pyMysqL安装

方式一:使用命令安装

pip install pyMysqL

方式二:PyCharm内部安装

watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=

导入模块:

import pyMysqL

pyMysqL流程及模块说明

01 pyMysqL操作流程

  1. 导入pyMysqL

  2. 建立数据库连接:使用pyMysqL的connect()方法连接数据,返回连接对象;

  3. 使用连接对象创建游标对象(用于操作sql);

  4. 准备写sql语句(select * from student);

  5. 使用游标对象执行sql;

  6. 查询数据使用游标获取;

  7. 关闭游标(先)和数据库连接(后)。

watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=

watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=

02 pyMysqL模块说明

▌Connection对象

表示:conn=connect(参数列表)

作用:用于建立与数据库的连接;

创建对象:调用connect()方法

参数列表:

  • host:连接的MysqL主机,如本机是'localhost';

  • port:连接的MysqL主机的端口,认是3306;

  • database:数据库名称

  • user:连接的用户名

  • password:连接的密码;

  • charset:通信采用的编码方式,推荐使用utf8;

▌对象的方法

对象方法如下:

  • close():关闭连接;

  • commit():提交;

  • cursor():返回Cursor对象,用于执行sql语句并获得结果;

  • execute(operation [, parameters ]):执行语句,返回受影响的行数,主要用于执行insert、update、delete语句,也可以执行create、alter、drop等语句;

  • fetchone():执行查询语句时,获取查询结果集的第一个行数据,返回一个元组

  • fetchall():执行查询时,获取结果集的所有行,一行构成一个元组,再将这些元组装入一个元组返回;

  • 关于pymysql防注入,字符串拼接查询,容易造成注入,为了避免注入,使用pyMysqL提供的参数化语句;

▌Cursor对象

游标(cursor)就是游动的标识,通俗的说,一条sql取出对应n条结果资源的接口/句柄,就是游标,沿着游标可以一次取出一行。

  • 用于执行sql语句,使用频度最高的语句为select、insert、update、delete;

  • 获取Cursor对象:调用Connection对象的cursor()方法:cs1=conn.cursor()



▌对象的属性

  • rowcount只读属性,表示最近一次execute()执行后受影响的行数;

  • connection获得当前连接对象;



pyMysqL语法基础

01 代码示例

import pyMysqL
# 连接数据库
conn = pyMysqL.connect(host='127.0.0.1', user='ITester', password='123456',
                       database='ITester', charset='utf8')
# 创建游标
cursor = conn.cursor()
# 执行sql语句
sql = 'select * from user limit 3;'
res = cursor.execute(sql)
# 获取查询结果的1条数据
data = cursor.fetchone()
print(data)
# 关闭游标连接
cursor.close()
# 关闭数据库连接
conn.close()

02 语法总结

1.连接数据库,需要host、user、password、database、charset等信息;

2.操作数据库先创建游标;

3.执行指定的sql语句,如果涉及到增、删、改数据库必须要conn.commit(),提交事务

4.查询获取数据条数有三种方法fetchone、fetchmany、fetchall。

5.需要注意的是,fetch获取的数据认是元组,如果想要字典类型,

cursor=pyMysqL.cursors.DictCursor;

6.先关闭游标,后关闭数据库连接;



封装数据库

01 封装说明

在实际项目中,很多地方都有用到数据库的操作,所以需要将数据库相关操作进行封装,方便其他模块调用
如下,在common目录下,新建文件db_handler.py 用于封装数据库操作。

watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=

watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=


db_handler.py
import pyMysqL
class DBHandler:
    def __init__(self,host,port,user,password,
                 database,charset,**kwargs):
        # 连接数据库服务器
        self.conn = pyMysqL.connect(host=host, port=port, user=user,password=password,
                                    database=database,cursorclass=pyMysqL.cursors.DictCursor,
                                    charset=charset,**kwargs)
        # 获取游标
        self.cursor = self.conn.cursor()
    
    def query(self, sql, args=None,one=True):
        self.cursor.execute(sql, args)
        # 提交事务
        self.conn.commit()
        if one:
            return self.cursor.fetchone()
        else:
            return self.cursor.fetchall()
    def close(self):
        self.cursor.close()
        self.conn.close()
if __name__ == "__main__":
    db = DBHandler(host='127.0.0.1', port=3306,
                   user='ITester', password='123456',
                   database='ITester', charset='utf8')
    sql = 'select * from user limit 1;'
    data = db.query(sql)
    print(data)

总结:本文主要介绍pyMysqL安装、操作流程、语法基础及封装操作数据库类。


版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐