什么要做python连接mysql,一般是解决什么问题的

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

  Python3如何连接Mysql呢?PyMySQL是在Py3版本用于连接Mysql


python连接mysql的模块安装

在线安装

pip install PyMySQL

在Pycharm---点击--Terminal---输入pip install PyMySQL等待完装完毕即可,如图所示

离线安装

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

  1. 下载所需要的模块包

  1. 解压该文件

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

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

  3. 等待完装完毕

  4. 导入模块 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、错误在哪一行

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 更新条件;
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()

运行结果

查询数据

查询单条数据

语法:

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()

运行结果

如果对软件测试、接口测试、自动化测试、技术同行、持续集成、面试经验交流。感兴趣可以进到893694563,群内会有不定期的分享测试资料。

如果文章对你有帮助,麻烦伸出发财小手点个赞,感谢您的支持,你的点赞是我持续更新的动力。

Python如何连接Mysql及基本操作的更多相关文章

  1. 使用Python编程语言连接MySQL数据库代码

    使用Python编程语言连接MySQL数据库代码,跟大家分享一下: 前几天我用python操作了mysql的数据库,发现非常的有趣,而且python操作mysql的方法非常的简单和快速,所以我把代码分 ...

  2. 通过python代码连接MySQL以及插入和显示数据

    通过python代码连接MySQL以及插入和显示数据: 数据库huahui创建一个shibie的表,里面有两个varcahr(100)的字段,num和result. import pymysql im ...

  3. python如何连接mysql数据库

    先花点时间来说说一个程序怎么和数据库进行交互1.和数据库建立连接2.执行sql语句,接收返回值3.关闭数据库连接使用MySQLdb也要遵循上面的几步.让我们一步步的进行. 1.MySQL数据库要用My ...

  4. python MySQLdb连接mysql失败(转载)

    最近了解了一下django,数据库选用了mysql, 在连接数据库的过程中,遇到一点小问题,在这里记录一下,希望能够对遇到同样的问题的朋友有所帮助,少走一些弯路.关于django,想在这里也额外说一句 ...

  5. python 简单连接mysql数据库

    1. 安装pymysql 库 pip install pymysql 2.实例本地连接mysql库 #!/usr/bin/python # encoding: utf-8 ""&q ...

  6. 在python中连接mysql数据库,并进行增删改查

    数据库在开发过程中是最常见的,基本上在服务端的编程过程中都会使用到,mysql是较常见的一种数据库,这里介绍python如果连接到数据库中,并对数据库进行增删改查. 安装mysql的python扩展 ...

  7. python无法连接mysql,有个小坑,需要注意一下!

    尝试用python链接mysql数据库,按照教程里链接了小半夜,就是没有链接上,找了各种文章,最后发现是版本的问题,我想使用的模块是MySQLdb,刚刚去他们的官网看了一下,最近一次更新是2014年, ...

  8. python MySQLdb连接mysql时报错

    故障现象: >>> import MySQLdb >>> conn = MySQLdb.connect(host=,charset="utf8" ...

  9. Python远程连接MySQL数据库

    使用Python连接数据库首先需要安装Python的数据库驱动. 我的本地只装了Python,并没有装MySQL,当我使用命令: sudo pip install mysql-python 安装驱动( ...

随机推荐

  1. C#中调用c++的dll具体创建与调用步骤,亲测有效~ (待验证)

    使用的工具是VS2010哦~其他工具暂时还没试过 我新建的工程名是my21dll,所以会生成2个同名文件.接下来需要改动的只有画横线的部分 下面是my21dll.h里面的... 下面的1是自动生成的不 ...

  2. Linux操作系统基本应用(完结)

      时间:2015-4-10 12:40Linux第一天 Linux基本命令  Linux各文件夹的作用    bin  二进制可执行命令    dev  设备特殊文件    etc  系统管理和配置 ...

  3. SprngCloud微服务框架搭建(一)

    参照来源 :https://blog.csdn.net/forezp/article/details/70148833 1.简介 目前来说,SpringCloud是比较完整的微服务解决方案框架.不像其 ...

  4. Java并发之AQS原理解读(三)

    上一篇:Java并发之AQS原理解读(二) 前言 本文从源码角度分析AQS共享锁工作原理,并介绍下使用共享锁的子类如何工作的. 共享锁工作原理 共享锁与独占锁的不同之处在于,获取锁和释放锁成功后,都会 ...

  5. Mysql索引最佳实践笔记0524

    #mysql5.7 innodb默认存储引擎 一.关于索引二.最佳实践三.避坑实践 一.关于索引 1.索引的作用 -提高查询效率 -数据分组.排序 -避免回表查询 -优化聚集查询 -用于多表join关 ...

  6. CSS布局中最小高度的妙用

    CSS布局中最小高度的妙用 --最小高度可以设定一个BOX的最小高度,当其内容较少时时,也能保持BOX的高度为一定,超出就自动向下延伸最小高度可以设定一个BOX的最小高度,当其内容较少时时,也能保持B ...

  7. 常用ADB命令汇总

    网络连接 通过TCP/IP连接设备 adb connect <ip:port> 断开已有的TCP/IP连接 adb disconnect <ip:port> 监听设备上指定的端 ...

  8. Walker

      emmm.......随机化.   好吧,我们不熟.   考虑随机选取两组数据高斯消元消除结果后带入检验,能有超过1/2正确就输出.   其实方程就四个,手动解都没问题.   只是要注意看sin与 ...

  9. Mysql常用sql语句(6)- limit 限制查询结果的条数

    测试必备的Mysql常用sql语句系列 https://www.cnblogs.com/poloyy/category/1683347.html 前言 实际工作中,我们的数据表数据肯定都是万级别的,如 ...

  10. java代码覆盖实战

    Jacoco原理 代码插桩 On-the-fly插桩: JVM中通过-javaagent参数指定特定的jar文件启动Instrumentation的代理程序,代理程序在通过Class Loader装载 ...