用python实现接口测试(四、操作MySQL)

一、MySQL简介

使用Python进行MySQL的库主要有三个,Python-MySQL(更熟悉的名字可能是MySQLdb),PyMySQL和SQLAlchemy。

Python-MySQL资格最老,核心由C语言打造,接口精炼,性能最棒,缺点是环境依赖较多,安装复杂,近两年已停止更新,只支持Python2,不支持Python3。

PyMySQL为替代Python-MySQL而生,纯python打造,接口与Python-MySQL兼容,安装方便,支持Python3。

SQLAlchemy是一个ORM框架,它并不提供底层的数据库操作,而是要借助于MySQLdb、PyMySQL等第三方库来完成,目前SQLAlchemy在Web编程领域应用广泛。

二、MySQL安装方式

软件版本:

MYQSL:mysql-5.7.17

PYTHON:Python 3.4.4

1.电脑端的安装MYQSL来作为server:详情操作步骤见MySQL+Python 3.4.4MySQL图文安装教程

2.Python端安装pymysql,简单的命令安装方式:pip install pymysql

离线安装方式:下载MySQL安装包后执行命令pip install pymysql-x.x.x.tar.gz

安装成功标志

三、数据库常用指令

1.Python下链接数据库的接口解析:

pymysql.Connect()参数说明

host(str):      MySQL服务器地址

port(int):      MySQL服务器端口号

user(str):      用户名

passwd(str):    密码

db(str):        数据库名称

charset(str):  连接编码

connection对象支持的方法

cursor()        使用该连接创建并返回游标

commit()        提交当前事务

rollback()      回滚当前事务

close()        关闭连接

cursor对象支持的方法

execute(op)    执行一个数据库的查询命令

fetchone()      取得结果集的下一行

fetchmany(size) 获取结果集的下几行

fetchall()      获取结果集中的所有行

rowcount()      返回数据条数或影响行数

close()        关闭游标对象

2.数据库游标对象cursor支持的方法:

游标cursor方法

3.MySQL数据库常用指令:

show databases;      // 查看当前所有的数据库

create database user;   //创建user数据库

use test;     //作用与test数据库

show tables;    //查看test库下面的表

CREATE  TABLE  user (name VARCHAR(20),password VARCHAR(20));    //创建user表,name 和password 两个字段

insert into user values('Tom','1321');   //向user表内插入若干条数据

select * from user;      //查看user表的数据

delete from user where name = 'Jack';   //删除name 等于Jack的数据

update user set password='1111' where name = 'Alen';    //修改name等于Alen 的password 为 1111

 select * from user;    //查看表内容

四、MySQL操作指令之连接操作

pycharm+pymysql连接mysql之前先打开MySQL server服务端

MySQL server 5.7

连接操作需知道主机地址host、端口port、用户名user、用户密码password、数据库名和编码方式charset(编码方式可写可不写)

数据库连接操作

创建数据表

创建数据表

五、MySQL操作指令之插入操作

插入多条数据

六、MySQL操作指令之查询操作

查询数据操作

七、MySQL操作指令之更新操作

更新数据操作

八、MySQL操作指令之删除操作

删除操作

九、数据库代码重构

1.直接上代码---pymysql.py

#coding:utf-8

import pymysql

import config

import pymysql.cursors

class PyMySQLHelper(object):

def __init__(self):

self.conn = config.conn_dict

def get_one(self, sql, params):

conn = pymysql.connect(**self.conn)

cur = conn.cursor(cursor = pymysql.cursors.DictCursor)

retCount = cur.execute(sql, params)

data = cur.fetchone()

cur.close()

conn.close()

return data

def get_many(self, sql, params):

conn = pymysql.connect(**self.conn)

cur = conn.cursor(cursor = pymysql.cursors.DictCursor)

retCount = cur.execute(sql, params)

data = cur.fetchall()

cur.close()

conn.close()

return data

def insert_one(self, sql, params):

conn = pymysql.connect(**self.conn)

cur = conn.cursor()

cur.execute(sql, params)

conn.commit()

cur.close()

return u'插入数据库成功'

    def insert_many(self, sql, params):

conn = pymysql.connect(**self.conn)

cur = conn.cursor()

cur.executemany(sql, params)

conn.commit()

cur.close()

return u'批量插入数据库成功'

    def update_one(self, sql, params):

conn = pymysql.connect(**self.conn)

cur = conn.cursor(cursor = pymysql.cursors.DictCursor)

ret = cur.execute(sql, params)

conn.commit()

cur.close()

conn.close()

return u'更新数据库成功'

    def delete_one(self, sql, params):

conn = pymysql.connect(**self.conn)

cur = conn.cursor(cursor = pymysql.cursors.DictCursor)

ret = cur.execute(sql, params)

conn.commit()

cur.close()

conn.close()

return u'删除数据库成功'

class CheckUser(object):

def __init__(self):

self.__helper = PyMySQLHelper()

def checkValid(self, name, password):

sql ='select * from user where name=%s and password=%s'

        params = (name, password)

return self.__helper.get_one(sql, params)

def info():

name =raw_input(u'请输入你的用户名:')

password =raw_input(u'请输入你的密码:')

user = CheckUser()

result = user.checkValid(name, password)

if not result:

print u'用户名或者密码错误,请联系管理员'

    else:

print u'恭喜您,输入正确!'

if __name__ =='__main__':

info()

config.py

#coding:utf-8

conn_dict=dict(host='127.0.0.1', user='root', passwd='123456', db='user',charset='utf8')

2.查看数据库用户名称和密码

user数据库中的用户名和密码

3.运行上述代码,输入user数据库中的用户名和密码进行测试

运行结果

MySQL练习暂时告一段落,以上代码还需继续优化,不然每次操作数据库时不注销掉创建表格等操作的话会导致代码运行提示错误,后续继续优化代码。。。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,616评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,020评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,078评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,040评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,154评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,265评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,298评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,072评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,491评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,795评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,970评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,654评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,272评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,985评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,223评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,815评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,852评论 2 351

推荐阅读更多精彩内容