zoukankan      html  css  js  c++  java
  • 接口测试基础七--接口测试数据的验证

    去数据表中检查数据的过程就是接口的数据验证。

    数据验证的基本思路:

    1、准备查询sql,多条sql,同样做编号,接口调用前执行查询,对查询结果编号并记录下来;

    2、准备查询sql,多条sql,同样做编号,接口调用后执行查询,对查询结果编号并记录下来;

    3、比对两次的查询数据结果

     


    那么python3如何连接mysql呢?PyMySQL 是在 Python3.x 版本中用于连接 MySQL 服务器的一个库,Python2中则使用mysqldb。

    环境准备:
    python3.6
    PyMySQL  0.9.2

    环境准备

    使用pip安装PyMySQL

    pip install PyMySQL

    先使用第三方工具连接mysql数据库,比如navicat连接mysql,参考这篇https://www.cnblogs.com/yoyoketang/p/9994078.html

    如下图连接测试通过,那么连接数据库至少应该知道这些信息,用户名和密码是授权远程客户端的用户名和密码,授权相关参考这篇https://www.cnblogs.com/yoyoketang/p/10268896.html

    连接名: 自己定义,这个无所谓
    主机名或ip地址:mysql服务的ip地址
    端口:3306 (端口号,默认一般是3306)
    用户名:root (授权远程登录的用户名)
    密码:123456 (授权远程登录的密码)

    查询操作

    如果新建了一个test数据库,里面有一张user表,有name和psw两个字段,使用sql查询结果如下

    select name,psw from user

    接下来使用python转换成对应的代码查询

    import pymysql
    
    # 打开数据库连接
    db = pymysql.connect(host='47.104.x.x',
                         port=3306,
                         user='root',
                         passwd='123456',
                         db='test')
    
    # 使用 cursor() 方法创建一个游标对象cur
    cur = db.cursor()
    
    # 使用 execute()  方法执行 SQL 查询
    cur.execute("select name, psw from user")
    
    # 使用 fetchall() 方法获取查询结果
    data = cur.fetchall()
    
    print(data)
    
    # 关闭数据库连接
    db.close()

    运行结果:

    ((‘yoyo_1’, ‘111111’), (‘yoyo’, ‘123456’), (‘yoyo_2’, ‘111111’), (‘yoyo_3’, ‘222222’), (‘yoyo_4’, ‘444444’))

    有时候我们只想查询某个字段对应的值,比如查询yoyo_1账号对应的psw值,并且取出来

    select psw from user where name=’yoyo_1’

    查询的结果是((‘111111’,),) 元组嵌套元组,取值的话用下标取出来就可以了

    import pymysql
    
    def select_db(sql):
        '''查询数据库'''
        # 打开数据库连接
        db = pymysql.connect(host='47.104.x.x',
                             port=3306,
                             user='root',
                             passwd='123456',
                             db='test')
    
        # 使用 cursor() 方法创建一个游标对象cur
        cur = db.cursor()
    
        # 使用 execute()  方法执行 SQL 查询
        cur.execute(sql)
    
        # 使用 fetchall() 方法获取查询结果
        data = cur.fetchall()
        # print(data)  # 取出对应的psw值
    
        # 关闭数据库连接
        db.close()
        return data
    
    if __name__ == "__main__":
        sql = "select psw from user where name='yoyo_3'"
        a = select_db(sql)[0][0]
        print("查询结果:%s" %str(a))

    删除操作

    使用python删除一条数据,比如我要删除yoyo_1这条记录

    delete from user where name=’yoyo_1’

    import pymysql
    
    def delete_db(sql_delete):
        '''删除操作'''
        # 打开数据库连接
        db = pymysql.connect(host='47.104.x.x',
                             port=3306,
                             user='root',
                             passwd='123456',
                             db='test')
    
        # 使用cursor()方法获取操作游标
        cur = db.cursor()
    
        try:
            cur.execute(sql_delete)  # 执行
            # 提交
            db.commit()
        except Exception as e:
            print("操作异常:%s" % str(e))
            # 错误回滚
            db.rollback()
        finally:
            db.close()
    
    if __name__ == '__main__':
        sql_delete ="delete from user where name='yoyo_1' "
        delete_db(sql_delete)

    更新操作

    更新name用户名是yoyo的用户,把psw改成666666

    update user set psw=’666666’ where name=’yoyo’

    import pymysql
    
    def update_db(sql_update):
        '''3.更新操作'''
        db = pymysql.connect(host='47.104.x.x',
                             port=3306,
                             user='root',
                             passwd='123456',
                             db='test')
    
        # 使用cursor()方法获取操作游标
        cur = db.cursor()
    
        try:
            cur.execute(sql_update)  # 执行sql
            # 提交
            db.commit()
        except Exception as e:
            # 错误回滚
            print("错误信息:%s" % str(e))
            db.rollback()
        finally:
            db.close()
    
    if __name__ == '__main__':
        sql_update ="update user set psw='666666' where name='yoyo'"
        update_db(sql_update)

    新增数据

    往数据库里面插入一条数据,比如在user表里面新增一个用户信息yoyo_10,123456

    insert into user(id, name, psw) values(10, ‘yoyo_10’, ‘123456’)

    import pymysql
    
    def insert_db(sql_insert):
        '''插入操作'''
        db = pymysql.connect(host='47.104.x.x',
                             port=3306,
                             user='root',
                             passwd='123456',
                             db='test')
        # 使用cursor()方法获取操作游标
        cur = db.cursor()
    
        try:
            cur.execute(sql_insert)
            # 提交
            db.commit()
        except Exception as e:
            print("错误信息:%s" % str(e))
            # 错误回滚
            db.rollback()
        finally:
            db.close()
    
    if __name__ == "__main__":
        sql_insert = "insert into user(id, name, psw) values(10, 'yoyo_10', '123456')"
        insert_db(sql_insert)

    从上面的代码可以看出,除了查询的代码不一样,新增、删除、更新数据库操作代码都一样,只是执行的sql不一样

  • 相关阅读:
    FCC---Learn How Bezier Curves Work---定义坐标轴点的值,影响斜率,改变速度。具体调试换值既可以体会
    FCC---Change Animation Timing with Keywords--两个小球从A都B,相同循环时间 duration, 不同的速度 speed
    FCC---Animate Multiple Elements at Variable Rates---还可以改循环时间,达到不同律动频率的效果
    FCC---Animate Elements at Variable Rates----一闪一闪亮晶晶,不同的闪动节奏
    FCC---Make a CSS Heartbeat using an Infinite Animation Count----超级好看的心跳,粉色的
    FCC---Animate Elements Continually Using an Infinite Animation Count---设置animation-iteration-count的次数为无限,让小球一直跳动
    FCC---Create Visual Direction by Fading an Element from Left to Right---一个带好看背景色的圆形图案,从左到右移动,透明度opacity渐变为0.1,背景色渐渐消失的效果
    FCC---Create Movement Using CSS Animation---设计一个盒子上下左右移动,结合animation, @keyframe, position (上下左右的offset)
    FCC---Use CSS Animation to Change the Hover State of a Button---鼠标移过,背景色变色,用0.5s的动画制作
    Python入门必学知识,30万年薪Python工程师带你学
  • 原文地址:https://www.cnblogs.com/123blog/p/10296399.html
Copyright © 2011-2022 走看看