一看就懂Python连接mysql数据, 一步步教会你!

12 篇文章 0 订阅
1 篇文章 0 订阅

为什么要做python连接mysql,一般是解决什么问题的呢?今天艺霏和大家分享这个内容。

做自动化测试时候,注册了一个新用户,产生了多余的数据,下次同一个账号就无法注册了,这种情况怎么办呢?自动化测试都有数据准备和数据清理的操作,如果因此用例产生了多余数据,就需要清理数据,可以用Pyhthon连接Mysql直接删除多余的数据就可以了。

Python3如何连接Mysql呢?PyMySQL是在Py3版本用于连接Mysql
python连接mysql的模块安装
在线安装

pip install PyMySQL

在Pycharm—点击–Terminal—输入pip install PyMySQL等待完装完毕即可,如图所示
在这里插入图片描述离线安装

有时候在线安装第三方模块的时,会因为网络原因总是装不上,那怎么办呢?那就手动安装

 1.  下载所需要的模块包

在这里插入图片描述
2.解压该文件
在这里插入图片描述

将文件名改短,然后放入非C盘且放在根目录

打开cmd---->E:---->cd xlrd---->python setup.py install

等待完装完毕

导入模块 import xlrd,运行如果没报错就说明安装正常

连接MySql

import pymysql
# 打开数据库连接
db = pymysql.connect("localhost", "root", "111223", "study_date")

# 使用 cursor() 方法创建一个游标对象 cursor
cursor = db.cursor()

# 使用 execute()  方法执行 SQL 查询
cursor.execute("SELECT VERSION()")

# 使用 fetchone() 方法获取单条数据.
data = cursor.fetchone()

print("Database version : %s " % data)

# 关闭数据库连接
db.close()

运行结果
在这里插入图片描述
数据库基本操作
增加数据

insert 语句可以用来将一行或多行数据插到数据库表中, 使用的一般形式如下:

insert [into] 表名 [(列名1, 列名2, 列名3, ...)] values (1,2,3, ...);

其中 [ ] 内的内容是可选的, 例如, 要给study_date数据库中的 studys 表插入一条记录, 执行语句:

 1 import pymysql
 2 
 3 # 打开数据库连接
 4 db = pymysql.connect("localhost", "root", "111223", "study_date")
 5 # 使用cursor()方法获取操作游标
 6 cursor = db.cursor()
 7 insert_sql = 
 8 # 执行sql语句
 9 cursor.execute("insert into studys(id, name, age) values(3, '骑着乌龟赶猪', 35)") 
10 # 提交到数据库执行 
11 db.commit() cursor.execute("select * from studys")
12 # 查看表里所有数据 
13 data = cursor.fetchall() 
14 print(data) # 关闭数据库连接 db.close()

运行结果
在这里插入图片描述再运行一次上以代码,运行后报错,两个重要错误信息

1、错误在哪一行

img
在这里插入图片描述2、错误原因
在这里插入图片描述为防止插入数据时出现异常,所以加上try…except

 1 import pymysql
 2 
 3 # 打开数据库连接
 4 db = pymysql.connect("localhost", "root", "111223", "study_date")
 5 
 6 # 使用cursor()方法获取操作游标
 7 cursor = db.cursor()
 8 insert_sql = "insert into studys(id, name, age) values(3, '骑着乌龟赶猪', 35)"
 9 try:
10     # 执行sql语句
11     cursor.execute(insert_sql)
12     # 提交到数据库执行
13     db.commit()
14     cursor.execute("select * from studys")
15     # 查看表里所有数据
16     data = cursor.fetchall()
17     print(data)
18 except:
19     print("数据插入失败,请查检try语句里的代码")
20     # 关闭数据库连接
21     # 如果想知道报了啥错,可以主动抛出异常
22     # raise 
23     db.close()

运行结果:
在这里插入图片描述
删除数据

delete 语句用于删除表中的数据

delete from 表名称 where 删除条件;

import pymysql

# 打开数据库连接
db = pymysql.connect("localhost", "root", "111223", "study_date")

# 使用cursor()方法获取操作游标
cursor = db.cursor()
check_sql = 'select * from studys'
# SQL 删除数据
del_sql = "delete from studys where id=3"
try:
    # 执行sql语句
    cursor.execute(del_sql)
    # 提交到数据库执行
    db.commit()
    cursor.execute(check_sql)
    # 查看表里所有数据
    data = cursor.fetchall()
    print(data)
except:
    # 如果发生错误则回滚
    db.rollback()

# 关闭数据库连接
db.close()

运行结果
在这里插入图片描述修改数据

update 语句可用来修改表中的数据

update 表名称 set 列名称=新值 where 更新条件;
update studys set age=25 where id=1

import pymysql

# 打开数据库连接
db = pymysql.connect("localhost", "root", "111223", "study_date")

# 使用cursor()方法获取操作游标
cursor = db.cursor()

check_sql = 'select * from studys'
# SQL 修改数据
updata_sql = "update studys set age=30 where id=2"
try:
    # 执行sql语句
    cursor.execute(updata_sql)
    # 提交到数据库执行
    db.commit()
    cursor.execute(check_sql)
    # 查看表里所有数据
    data = cursor.fetchall()
    print(data)
except:
    # 如果发生错误则回滚
    db.rollback()

# 关闭数据库连接
db.close()

运行结果

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-vsL0oPX4-1595926245230)(C:\Users\zhuzhichao\AppData\Roaming\Typora\typora-user-images\image-20200724202540695.png)]
查询数据
查询单条数据

语法:

fetchone()

例如要查询 students 表中所有学生的名字和年龄, 输入语句

select name, age from studys

fetchone()获取一行数据

 1 # 导入模块
 2 import pymysql
 3 
 4 # 打开数据库连接     数据库地址
 5 db = pymysql.connect("localhost", "root", "111223", "study_date")
 6 
 7 # 使用 cursor() 方法创建一个游标对象 cursor
 8 cursor = db.cursor()
 9 
10 # 使用 execute()方法执行 SQL 查询
11 # 通配符,意思是查询表里所有内容
12 cursor.execute("select * from studys")
13 
14 # 使用 fetchone() 方法获取一行数据.
15 data = cursor.fetchone()
16 print(data)
17 
18 # 关闭数据库连接
19 db.close()

运行结果:
在这里插入图片描述
查询多条数据

fetchall()获取所有数据

 1 # 导入模块,固定写法
 2 import pymysql
 3 
 4 # 打开数据库连接     数据库地址
 5 db = pymysql.connect("localhost", "root", "111223", "study_date")
 6 
 7 # 使用 cursor() 方法创建一个游标对象 cursor
 8 cursor = db.cursor()
 9 
10 # 使用 execute()  方法执行 SQL 查询
11 cursor.execute("select * from studys")
12 
13 # 使用 fetchall() 方法获取所有数据.以元组形式返回
14 data = cursor.fetchall()
15 print(data)
16 
17 # 关闭数据库连接
18 db.close()

运行结果
在这里插入图片描述如果对软件测试、接口测试、自动化测试、技术同行、持续集成、面试经验交流。感兴趣可以进到我自己创建的一个软件测试交流群,QQ:624830685,群内会有不定期的分享测试资料。
如果文章对你有帮助,麻烦伸出发财小手点个赞,感谢您的支持,你的点赞是我持续更新的动力。另外给我点赞三连吧,我更加开心哇!

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值