Python工具类(一)—— 操作Mysql数据库

本文涉及的产品
RDS AI 助手,专业版
RDS DuckDB + QuickBI 企业套餐,8核32GB + QuickBI 专业版
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
简介: Python工具类(一)—— 操作Mysql数据库

如何调用直接看__main__函数里如何调用此工具类就阔以啦!

1 # encoding=utf-8
  2 import pymysql
  3 
  4 # 导入所有Mysql配置常量,请自行指定文件
  5 from conf.settings import *
  6 
  7 
  8 class MysqlConnection(object):
  9     """
 10     mysql操作类,对mysql数据库进行增删改查
 11     """
 12 
 13     def __init__(self, config):
 14         # Connect to the database
 15         self.connection = pymysql.connect(**config)
 16         self.connection.autocommit(True)
 17         self.cursor = self.connection.cursor()
 18 
 19     def QueryAll(self, sql):
 20         """
 21         查询所有数据
 22         :param sql:
 23         :return:
 24         """
 25         # 数据库若断开即重连
 26         self.reConnect()
 27 
 28         self.cursor.execute(sql)
 29         return self.cursor.fetchall()
 30 
 31     def QueryMany(self, sql, n):
 32         """
 33         查询某几条数据数据
 34         :param sql:
 35         :return:
 36         """
 37         # 数据库若断开即重连
 38         self.reConnect()
 39 
 40         self.cursor.execute(sql)
 41         return self.cursor.fetchmany(n)
 42 
 43     def QueryOne(self, sql):
 44         """
 45         查询某几条数据数据
 46         :param sql:
 47         :return:
 48         """
 49         # 数据库若断开即重连
 50         self.reConnect()
 51 
 52         self.cursor.execute(sql)
 53         return self.cursor.fetchone()
 54 
 55     # return self.cursor.fetchone()
 56 
 57     def reConnect(self):
 58         """
 59         重连机制
 60         :return:
 61         """
 62         try:
 63             self.connection.ping()
 64         except:
 65             self.connection()
 66 
 67     def Operate(self, sql, params=None, DML=True):
 68         """
 69         数据库操作:增删改查
 70         DML: insert / update / delete
 71         DDL: CREATE TABLE/VIEW/INDEX/SYN/CLUSTER
 72         """
 73         try:
 74             # 数据库若断开即重连
 75             self.reConnect()
 76 
 77             with self.connection.cursor() as cursor:
 78                 cursor.execute(sql, params)
 79 
 80                 self.connection.commit()
 81 
 82         except Exception as e:
 83             if DML:
 84                 # 涉及DML操作时,若抛异常需要回滚
 85                 self.connection.rollback()
 86             print(e)
 87 
 88     def __del__(self):
 89         """
 90         MysqlConnection实例对象被释放时调用此方法,用于关闭cursor和connection连接
 91         """
 92         self.cursor.close()
 93         self.connection.close()
 94 
 95 
 96 if __name__ == "__main__":
 97     # 初始化MysqlConnection实例对象需要传Mysql配置信息的字典
 98     config = {'host': MYSQL_HOST, 'charset': CHARSET, 'db': DB, 'user': USER, 'port': MYSQL_PORT, 'password': PASSWORD}
 99     msc = MysqlConnection(config)
100     sql = "delete from users where username ='%s'" % "123456"
101 
102     print(msc.Operate(sql))
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
SQL 关系型数据库 MySQL
MySQL操作利器——mysql-connector-python库详解
MySQL操作利器——mysql-connector-python库详解
2775 0
|
关系型数据库 MySQL 数据库
Python处理数据库:MySQL与SQLite详解 | python小知识
本文详细介绍了如何使用Python操作MySQL和SQLite数据库,包括安装必要的库、连接数据库、执行增删改查等基本操作,适合初学者快速上手。
1318 15
|
SQL 关系型数据库 MySQL
Python中使用MySQL模糊查询的方法
本文介绍了两种使用Python进行MySQL模糊查询的方法:一是使用`pymysql`库,二是使用`mysql-connector-python`库。通过这两种方法,可以连接MySQL数据库并执行模糊查询。具体步骤包括安装库、配置数据库连接参数、编写SQL查询语句以及处理查询结果。文中详细展示了代码示例,并提供了注意事项,如替换数据库连接信息、正确使用通配符和关闭数据库连接等。确保在实际应用中注意SQL注入风险,使用参数化查询以保障安全性。
|
关系型数据库 MySQL 数据库
Mysql学习笔记(四):Python与Mysql交互--实现增删改查
如何使用Python与MySQL数据库进行交互,实现增删改查等基本操作的教程。
256 1
|
关系型数据库 MySQL 数据库
Python MySQL查询返回字典类型数据的方法
通过使用 `mysql-connector-python`库并选择 `MySQLCursorDict`作为游标类型,您可以轻松地将MySQL查询结果以字典类型返回。这种方式提高了代码的可读性,使得数据操作更加直观和方便。上述步骤和示例代码展示了如何实现这一功能,希望对您的项目开发有所帮助。
667 4
|
关系型数据库 MySQL Python
mysql之python客户端封装类
mysql之python客户端封装类
|
关系型数据库 MySQL Python
pymysql模块,python与MySQL之间的交互
pymysql模块,python与MySQL之间的交互
|
SQL 关系型数据库 MySQL
Python之MySQL操作及Paramiko模块操作
Python之MySQL操作及Paramiko模块操作
|
关系型数据库 MySQL 大数据
教你使用Python玩转MySQL数据库,大数据导入不再是难题!
教你使用Python玩转MySQL数据库,大数据导入不再是难题!
415 1

推荐镜像

更多
下一篇
开通oss服务