【接口测试】5_PyMySQL模块 _数据库工具类封装

文章目录

一、封装的目的

  • 将 数据库常用的操作,封装成类中的方法。 将来在使用时,只需提供 要执行的SQL语句,给这个方法,即可执行。
  • 使用者,不需要关心:建立连接、创建游标、关闭游标、关闭连接

二、封装实现(重点)

类方法,可以用类名直接调用,添加装饰器。

python 复制代码
类方法:create_conn()     // 获取数据库连接

类方法:close_conn()      // 关闭数据库连接

类方法:query_one(sql)    // 查询一条数据

类方法:db_uid(sql)       // 执行数据库增删改

要求:定义一个DBTools工具类,对外提供以上方法

三、搭建框架

python 复制代码
# 定义 数据库工具类
class DBTools(object):
    
    # 创建连接
    def create_conn(self):
        pass

    # 查一条记录
    def query_one(self, sql):
        pass
        # 创建连接
        # 创建游标
        # 关闭游标
        # 关闭连接

    # 增删改记录
    def db_uid(self, sql):
        pass
        # 创建连接
        # 创建游标
        # 关闭游标
        # 关闭连接

四、案例(重点)

id title pub_date read comment is_delete
1 射雕英雄传 1960-05-01 12 34 0
2 天龙八部 1966-07-24 37 40 0
3 笑傲江湖 1995-12-24 23 80 0

4.1 设置私有方法

让创建连接方法 create_conn( ) 对用户不可见(对用户没用),但是又不影响后面查询和修改方法使用。

--->设置私有方法 __create_conn( )

python 复制代码
# 定义 数据库工具类
class DBTools(object):
    # 创建连接 - 类方法。可以直接使用类名调用!
    @classmethod
    def __create_conn(cls):
        conn = pymysql.connect(host="172.16.28.4", port=3306, user="root", password="root",
                               database="books", charset="utf8")
        # 不能遗漏(创建连接之后,要返回结果)
        return conn

4.2 实现类方法

4.2.1 查询一条记录

python 复制代码
import pymysql

# 定义 数据库工具类
class DBTools(object):
    # 创建连接 - 类方法。可以直接使用类名调用!
    @classmethod
    def __create_conn(cls):
        conn = pymysql.connect(host="172.16.28.4", port=3306, user="root", password="root",
                               database="books", charset="utf8")
        # 不能遗漏(创建连接之后,要返回结果)
        return conn

# 查一条记录 - 封装为类方法,方便调用
    @classmethod
    def query_one(cls, sql):
        my_conn = None
        my_cursor = None
        res = None
        try:
            # 创建连接。借助类名,调用 类方法 create_conn。
            my_conn = DBTools.__create_conn()   # 接收 return conn返回的结果,给my_conn
 
            # 创建游标
            my_cursor = my_conn.cursor()
            # 执行 sql 语句,做查询
            my_cursor.execute(sql)
            # 提取一条记录
            res = my_cursor.fetchone()
        except Exception as err:
            print("执行查询SQL失败:", str(err))
        finally:
            # 关闭游标
            my_cursor.close()
            # 关闭连接
            my_conn.close()
            # 返回查询结果
            return res
        
        
if __name__ == '__main__':
	result = DBTools.query_one("select * from t_book;")
    print("查询语句的结果:", result)

4.2.2 增删改数据

python 复制代码
import pymysql

# 定义 数据库工具类
class DBTools(object):
    # 创建连接 - 类方法。可以直接使用类名调用!
    @classmethod
    def __create_conn(cls):
        conn = pymysql.connect(host="172.16.28.4", port=3306, user="root", password="root",
                               database="books", charset="utf8")
        # 不能遗漏
        return conn

# 增删改记录
    @classmethod
    def db_uid(cls, sql):
        my_conn = None
        my_cursor = None
        try:
            # 创建连接.
            my_conn = DBTools.__create_conn()  
            # 创建游标
            my_cursor = my_conn.cursor()
            # 执行 增删改 语句
            my_cursor.execute(sql)
            print("Affected rows:", my_conn.affected_rows())
            # 提交事务
            my_conn.commit()
        except Exception as err:
            print("执行 增删改 SQL 失败:", str(err))
            # 回滚事务
            my_conn.rollback()
        finally:
            # 关闭游标
            my_cursor.close()
            # 关闭连接
            my_conn.close() 
          
if __name__ == '__main__':
    DBTools.db_uid("update t_book set `read` = 100 where id = 3;")

4.3 完整代码实现

文件:py08_db_tools.py

python 复制代码
import pymysql

# 定义 数据库工具类
class DBTools(object):
    # 创建连接 - 类方法。可以直接使用类名调用!
    @classmethod
    def __create_conn(cls):
        conn = pymysql.connect(host="172.16.28.4", port=3306, user="root", password="root",
                               database="books", charset="utf8")
        # 不能遗漏
        return conn

    # 查一条记录 - 封装为类方法,方便调用
    @classmethod
    def query_one(cls, sql):
        my_conn = None
        my_cursor = None
        res = None
        try:
            # 创建连接, 借助类名,调用 类方法 create_conn
            my_conn = DBTools.__create_conn()
            # 创建游标
            my_cursor = my_conn.cursor()
            # 执行 sql 语句,做查询
            my_cursor.execute(sql)
            # 提取一条记录
            res = my_cursor.fetchone()
        except Exception as err:
            print("执行查询SQL失败:", str(err))
        finally:
            # 关闭游标
            my_cursor.close()
            # 关闭连接
            my_conn.close()
            # 返回查询结果
            return res

    # 增删改记录
    @classmethod
    def db_uid(cls, sql):
        my_conn = None
        my_cursor = None
        try:
            # 创建连接
            my_conn = DBTools.__create_conn()
            # 创建游标
            my_cursor = my_conn.cursor()
            # 执行 增删改 语句
            my_cursor.execute(sql)
            print("Affected rows:", my_conn.affected_rows())
            # 提交事务
            my_conn.commit()
        except Exception as err:
            print("执行 增删改 SQL 失败:", str(err))
            # 回滚事务
            my_conn.rollback()
        finally:
            # 关闭游标
            my_cursor.close()
            # 关闭连接
            my_conn.close()

if __name__ == '__main__':
    result = DBTools.query_one("select * from t_hero;")
    print("查询语句的结果:", result)

    DBTools.db_uid("update t_book set `read` = 100 where id = 3;")

五、小结

相关推荐
2301_814590253 分钟前
Python深度学习入门:TensorFlow 2.0/Keras实战
jvm·数据库·python
VALENIAN瓦伦尼安教学设备13 分钟前
设备对中不良的危害
数据库·嵌入式硬件·算法
小兔崽子去哪了25 分钟前
Docker 安装 PostgreSQL
数据库·后端·postgresql
野犬寒鸦29 分钟前
Redis热点key问题解析与实战解决方案(附大厂实际方案讲解)
服务器·数据库·redis·后端·缓存·bootstrap
mldlds1 小时前
Windows安装Redis图文教程
数据库·windows·redis
Y001112361 小时前
JDBC原理
java·开发语言·数据库·jdbc
超级大只老咪1 小时前
固定个数的状态,需要按顺序无限循环切换
数据库
@insist1232 小时前
数据库系统工程师-云计算与大数据核心知识
大数据·数据库·云计算·软考·数据库系统工程师·软件水平考试
皙然2 小时前
深度解析:关系型数据库与非关系型数据库(区别+原理+适用场景,一文吃透)
数据库·nosql
夕除2 小时前
Mysql
数据库·mysql