IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> requests+unittest接口自动化-mysql数据库类封装 -> 正文阅读

[大数据]requests+unittest接口自动化-mysql数据库类封装

文件路径:项目目录/common/mysql_handler.py

config.ini文件下数据库配置

mysql_handler.py

import pymysql
import json

from common.config_handler import conf

class OperateMysql(object):
    def __init__(self):
        # 数据库初始化连接

        self.conn = pymysql.connect(
            host=conf.get("mysqlconf_test_publication_house", "host"),
            user=conf.get("mysqlconf_test_publication_house", "user"),
            password=conf.get("mysqlconf_test_publication_house", "password"),
            database=conf.get("mysqlconf_test_publication_house", "db_name_base"),
            charset="utf8mb4",
            cursorclass=pymysql.cursors.DictCursor
        )

        # 创建游标操作数据库
        self.cur = self.conn.cursor()

    def select_first_data(self, sql):
        """
        查询第一条数据
        """
        try:
            # # 提交,防止事务冲突
            # self.conn.commit()

            # 执行 sql 语句
            self.cur.execute(sql)
        except Exception as e:
            print("执行sql异常:%s" % e)
        else:
            # 获取查询到的第一条数据
            first_data = self.cur.fetchone()
            # print(first_data)
            # 将返回结果转换成 str 数据格式,禁用acsii编码
            first_data = json.dumps(first_data, ensure_ascii=False)
            return first_data

    def select_all_data(self, sql):
        """
        查询结果集
        """
        try:
            self.cur.execute(sql)
        except Exception as e:
            print("执行sql异常:%s" % e)
        else:
            first_data = self.cur.fetchall()
            first_data = json.dumps(first_data, ensure_ascii=False)
            return first_data

    def get_count(self, sql):
        """
        获取数据条数
        """
        self.conn.commit()
        return self.cur.execute(sql)

    def del_data(self, sql):
        """
        删除数据
        """
        res = {}
        try:
            # 执行SQL语句
            result = self.cur.execute(sql)
            # print(result)
            if result != 0:
                # 提交修改
                self.conn.commit()
                res = {'删除成功'}
            else:
                res = {'没有要删除的数据'}
        except:
            # 发生错误时回滚
            self.conn.rollback()
            res = {'删除失败'}
        return res

    def update_data(self, sql):
        """
        修改数据
        """
        try:
            self.cur.execute(sql)
            self.conn.commit()
            res = {'更新成功'}
        except Exception as e:
            self.conn.rollback()
            res = {'更新删除'}
        return res

    def insert_data(self, sql, data):
        """
        新增数据
        """

        try:
            self.cur.execute(sql, data)
            self.conn.commit()
            res = {data, '新增成功'}
        except Exception as e:
            res = {'新增失败', e}
        return res

    def conn_close(self):
        # 关闭数据库
        self.cur.close()
        self.conn.close()


if __name__ == "__main__":

    om = OperateMysql(dbname="test_publication_house_base")
    sql = "select app_id,app_secret from company where pk_company='dada0a87-b700-4bf2-aa24-d884611c53d0'"
    one_data = om.select_first_data(sql)
    print(one_data)
    # 关闭数据库
    om.conn.close()


  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-01-03 16:10:38  更:2022-01-03 16:12:09 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/17 3:58:43-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码