python中的mysql操作教程及实例

一. 数据库在自动化测试中的应用

存测试数据

有的时候大批量的数据,我们需要存到数据库中,在测试的时候才能用到,测试的时候就从数据库中读取出来。这点是非常重要的!

存测试结果

二. python中的数据库之必备前提条件

1. 安装:pyMysql

python2中使用mysqldb,python3中不再支持,换成pyMysql

2. 安装步骤

  1. 安装pyMysql模块:pip install PyMysql

  2. python连接mysql数据库,需要下载驱动:https://dev.mysql.com/downloads/connector/python/mysqlmysql官方网站提供的驱动版本,目前只支持到python3.4,python版本要与驱动支持的版本匹配才能安装成功

  3. 安装mysql图形界面Navicat,连接数据库后,方便查看/编辑数据库数据

(可选)安装mysql服务端:https://dev.mysql.com/downloads/mysql/

3. 数据库的常规操作

增删改查,所以我们要学的也是利用python去数据库里面读取数据,进行增删改查操作

三. python—mysql操作

对数据库进行操作步骤:

  1. 连接数据库、创建游标

  2. 准备好增、删、改、查sql语句

  3. 执行sql语句

  4. 读取执行结果—执行影响的行

  5. 关闭游标、关闭连接(释放连接数)

数据库连接信息如下:

IP地址、端口号、数据库名字、登录用户名、密码

pymysql中的连接数据库方法:

conn = pymysql.Connect(host, port, db, user, passwd)

cursorclass = pymysql.cursors.DictCursor   指定返回数据为字典形式

创建游标:

cursor = conn.cursor()  每次操作都需要获取游标,才能进行

四. python之查询数据

1. 查询数据语法

sql语句:select 字段 from 表名 where 条件语句

2. 展示数据,需要调用如下函数

fetchall():返回的数据格式是列表形式的

fetchone():返回的数据格式是元组形式的(可以用cursorclass = pymysql.cursors.DictCursor改成字典的形式)

3. 条件语句的用法

重点看代码,掌握用法

五. python之execute

execute中,sql语句的多种方式:

execute(sql语句、参数[可选]):

  1. 数据直接写在sql语句中

  2. 用格式化的方式

sql语句中:列表和元组   %s代替

     字典:%(键名)s代替

参数:为真正的数值

例:

insert_sql = "insert into test1(id, name) values(%s, %s)"

data = [14, 'xiaojian']

#字典

data1 = {'id': 14, 'name': 'xiaojian'}

insert_sql = "insert into test1(id, name) values(%(id)s, %(name)s)"

 

cursor.execute(insert_sql, data) 

六. 提交和回滚

提交操作:在对数据库进行任何修改的情况下,都使用commit函数来提交操作

修改包括增加、修改、删除数据等操作

提交修改:

conn.commit()

回滚操作:在对数据库进行修改的过程中,因任何异常而导致修改中断,我们都应该使用回滚操作使数据库恢复到修改之前的状态

回滚修改:

conn.rollback()

七. 实例

实例1:增加数据

#引入相关的库
import pymysql

mysql_host = "localhost"
mysql_port = 3306
mysql_db = "xiaozhai"
mysql_user = "root"
mysql_passwd = "123456"

#连接操作:编码格式的指定,默认返回数据类型的指定 
conn = pymysql.Connect(host=mysql_host, user=mysql_user, password=mysql_passwd, 
          db=mysql_db, port=mysql_port, charset="utf8mb4", cursorclass=pymysql.cursors.DictCursor) 

#获取游标 cur = conn.cursor() 

#sql语句——增加数据 
sql_insert = "insert into python6(name, sex) values('xiaohua', 'female')" 
#执行sql语句 
try: 
  cur.execute(sql_insert) 
  conn.commit() 
except: 
  conn.rollback() 


#关闭连接、关闭游标 
cur.close() 
conn.close()

运行结果:
在这里插入图片描述

实例2:查询数据

#引入相关的库
import pymysql

mysql_host = "localhost"
mysql_port = 3306
mysql_db = "xiaozhai"
mysql_user = "root"
mysql_passwd = "123456"

#连接操作:编码格式的指定,默认返回数据类型的指定
conn = pymysql.Connect(host=mysql_host, user=mysql_user, password=mysql_passwd,
                db=mysql_db, port=mysql_port, charset="utf8mb4",
                cursorclass=pymysql.cursors.DictCursor)

#获取游标
cur = conn.cursor()

#查询语句
sql_select = "select * from python6"
#执行
cur.execute(sql_select)
#获取查询结果——会获取一条数据
data_a = cur.fetchone()
print(data_a)
print("=============================")
#获取查询结果——获取所有条数据(游标已经到了第二条,从第二条开始读)
data_all = cur.fetchall()
print(data_all)

#关闭连接、关闭游标
cur.close()
conn.close()

运行结果

{'id': 1, 'sex': 'male', 'name': 'xiaozhai'}
=============================
[{'id': 2, 'sex': 'male', 'name': 'xiaoli'}, {'id': 3, 'sex': 'female', 'name': 'xiaohua'}]

实例3:格式化方式插入数据

列表形式

#引入相关的库
import pymysql

mysql_host = "localhost"
mysql_port = 3306
mysql_db = "xiaozhai"
mysql_user = "root"
mysql_passwd = "123456"

#连接操作:编码格式的指定,默认返回数据类型的指定
conn = pymysql.Connect(host=mysql_host, user=mysql_user, password=mysql_passwd,
                db=mysql_db, port=mysql_port, charset="utf8mb4",
                cursorclass=pymysql.cursors.DictCursor)

#获取游标
cur = conn.cursor()

#格式化方式插入数据
data_list = ["xiaozhao", "female"]
sql_insert = "insert into python6(name, sex) values(%s, %s)"

#执行sql语句
try:
    cur.execute(sql_insert, data_list)
    conn.commit()
except:
    conn.rollback()


#关闭连接、关闭游标
cur.close()
conn.close()

运行结果
在这里插入图片描述
字典形式

#引入相关的库
import pymysql

mysql_host = "localhost"
mysql_port = 3306
mysql_db = "xiaozhai"
mysql_user = "root"
mysql_passwd = "123456"

#连接操作:编码格式的指定,默认返回数据类型的指定
conn = pymysql.Connect(host=mysql_host, user=mysql_user, password=mysql_passwd,
                db=mysql_db, port=mysql_port, charset="utf8mb4",
                cursorclass=pymysql.cursors.DictCursor)

#获取游标
cur = conn.cursor()

#格式化方式插入数据
data_dict = {"name": "xiaoliu", "sex":"female"}
sql_insert = "insert into python6(name, sex) values (%(name)s, %(sex)s)"

#执行sql语句
try:
    cur.execute(sql_insert, data_dict)
    conn.commit()
except:
    conn.rollback()


#关闭连接、关闭游标
cur.close()
conn.close()

运行结果
在这里插入图片描述

实例4:封装成类

import pymysql

class Mysql_Operate:

    def __init__(self, host, db, user, passwd, port=3306):
		#python学习交流群:711312441
        #连接数据库
        try:
            self.conn = pymysql.Connect(host=host, user=user, password=passwd,
                                   db=db, port=port, charset="utf8mb4",
                                   cursorclass=pymysql.cursors.DictCursor)
            #获取游标
            self.cur = self.conn.cursor()
            #没有异常,connect_flag为0
            self.connect_flag = 0
        except Exception as e:
            print(e)
            self.connect_flag = 1

    #查找
    def select_all_datas(self, select_sql):
        #查询数据——execute函数
        self.cur.execute(select_sql)
        #获取所有的数据并返回
        data_all = self.cur.fetchall()
        return data_all

    #更新数据
    def update_datas(self, update_sql ):
        try:
            self.cur.execute(update_sql)
            self.conn.commit()
            return True
        except:
            self.conn.rollback()
            return False

    #关闭数据库连接
    def close_db(self):
        self.cur.close()
        self.conn.close()


mysql_host = "localhost"
mysql_port = 3306
mysql_db = "xiaozhai"
mysql_user = "root"
mysql_passwd = "123456"

ms = Mysql_Operate(mysql_host, mysql_user, mysql_passwd, mysql_db)
if ms.connect_flag == 0:
    pass

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:python中的mysql操作教程及实例 - Python技术站

(0)
上一篇 2023年4月2日 下午4:08
下一篇 2023年4月2日

相关文章

  • 什么是Python装饰器?

    装饰器是Python中非常重要的一个概念,如果你会Python的基本语法,你可以写出能够跑通的代码,但是如果你想写出高效、简洁的代码,我认为离不开这些高级用法,当然也包括本文要讲解的装饰器,就如同前面提到的代码调试神器PySnooper一样,它就是主要通过装饰器调用的方式对Python代码进行调试。 1.什么是Python装饰器? 顾名思义,从字面意思就可以…

    Python开发 2023年3月31日
    00
  • python中5个带key的内置函数

    1.max取最大值函数 max() 方法返回给定参数的最大值,参数可以为序列。 lis = [1,2,3,-4] print(max(lis)) #返回lis列表中的最大值 ”’结果: 3 ”’ print(max(lis,key=abs)) #key参数指向绝对值函数,返回的结果是-4 2.min取最小值函数 min() 方法返回给定参数的最小值,参数…

    Python开发 2023年4月2日
    00
  • python进程池中的回调函数

    什么是回调函数 指定一个任务后、并且指定一个回调函数后,当指定的进程池执行的任务结束后,会将该任务的返回值作为回调函数的参数传递到回调函数中,并且回调函数得以执行 回调函数在主进程中被执行 import os from multiprocessing import Pool def func1(n): print(‘in func1’, os.getpid(…

    python 2023年4月17日
    00
  • Python中文分词库——jieba的用法

    1.介绍 jieba是优秀的中文分词第三方库。由于中文文本之间每个汉字都是连续书写的,我们需要通过特定的手段来获得其中的每个单词,这种手段就叫分词。而jieba是Python计算生态中非常优秀的中文分词第三方库,需要通过安装来使用它。 jieba库提供了三种分词模式,但实际上要达到分词效果只要掌握一个函数就足够了,非常的简单有效。 安装第三方库需要使用pip…

    python 2023年4月25日
    00
  • Python学习:标准库之数据持久存储与交换

    持久存储数据以便长期使用包括两个方面:在对象的内存中表示和存储格式之间来回转换数据,以及处理转换后数据的存储区。 标准库包含很多模块可以处理不同情况下的这两个方面 有两个模块可以将对象转换为一种可传输或存储的格式(这个过程被称为序列化)。最常用的是使用pickle持久存储,因为它可以与其他一些具体存储序列化数据的模块集成,如shelve。而对基于web的应用…

    Python开发 2023年4月2日
    00
  • Python学习: 网络请求模块 urllib 、requests

    Python 网络请求模块 urllib 、requests Python 给人的印象是抓取网页非常方便,提供这种生产力的,主要依靠的就是 urllib、requests这两个模块。 urlib 介绍 urllib.request 提供了一个 urlopen 函数,来实现获取页面。支持不同的协议、基本验证、cookie、代理等特性。 urllib 有两个版本…

    Python开发 2023年4月2日
    00
  • Python学习:构造函数与析构函数

    1.构造函数: __init__(self), 这个方法就是构造函数,在实例化的时候自动调用。 所有如果这个函数内有打印的方法,当实例出来的时候会打印里面的信息。 __init__方法的第一个参数永远都是self,表示创建实例本身,在__init__方法内部,可以把各种属性绑定到self,因为self指向创建的实例本身。 有了__init__方法,在创建实例…

    Python开发 2023年4月2日
    00
  • Python3教程:加密模块-hashlib

    一、哈希 1. 什么是可哈希(hashable) 简要的说,可哈希的数据类型,即不可变的数据结构(字符串str、元组tuple、对象集objects)。 2. 哈希有什么作用 它是一个将大体量数据转化为很小数据的过程,甚至可以仅仅是一个数字,以便我们可以用在固定的时间复杂度下查询它,所以,哈希对高效的算法和数据结构很重要。 3. 什么是不可哈希(unhash…

    Python开发 2023年4月2日
    00
合作推广
合作推广
分享本页
返回顶部