python dbUtil

2024-05-15 09:28
文章标签 python dbutil

本文主要是介绍python dbUtil,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

# -*- coding: utf-8 -*-    import pyodbc
import cx_Oracleclass Database:def __init__(self, driver, server, database, username, password):"""链接数据库:param driver:  数据库驱动:param server: 地址:端口:param database: 数据库名称:param username: 用户名:param password: 密码"""self.driver = driverself.database = databaseif self.database.upper() == '数据库':self.server = "地址:端口"self.username = "用户名"self.password = "密码"else:self.server = serverself.database = databaseself.username = usernameself.password = passwordself.connection = Noneself.cursor = Nonedef prepare(self, query):"""准备查询语句"""try:self.cursor.prepare(query)except Exception as e:print(f"准备查询语句时发生错误: {e}")def connect(self):"""连接数据库"""try:if self.driver == "ODBC Driver 17 for SQL Server":self.connection = pyodbc.connect(f"DRIVER={{{self.driver}}};SERVER={self.server};DATABASE={self.database};UID={self.username};PWD={self.password}")elif self.driver == "Oracle":self.connection = cx_Oracle.connect(f"{self.username}/{self.password}@{self.server}/{self.database}")self.cursor = self.connection.cursor()except Exception as e:print(f"连接数据库时出错: {e}")def execute_query(self, query):"""执行查询语句"""try:self.cursor.execute(query)return self.cursor.fetchall()except Exception as e:print(f"执行查询语句时出错: {e}")def execute_non_query(self, query):"""执行非查询语句"""try:self.cursor.prepare(query)self.cursor.execute(query)self.connection.commit()except Exception as e:print(f"执行非查询语句时出错: {e} | Error line: [{e.__traceback__.tb_lineno}]")def get_table_count(self, table_name, where_clause=None):"""获取表总数"""try:if where_clause:query = f"SELECT COUNT(*) FROM {table_name} where {where_clause}"else:query = f"SELECT COUNT(*) FROM {table_name}"self.cursor.execute(query)return self.cursor.fetchone()[0]except Exception as e:print(f"获取表总数时出错: {e}")def execute_batch_insert(self, table_name, data):"""执行批量插入语句"""try:query = f"INSERT INTO {table_name} VALUES "for row in data:query += f"({','.join([str(val) for val in row])}),"query = query[:-1]  # 去掉最后一个逗号self.cursor.execute(query)self.connection.commit()except Exception as e:print(f"执行批量插入语句时出错: {e}")def execute_many(self, query, params):"""执行多个参数的查询语句"""try:# print(query, params)self.cursor.executemany(query, params)self.connection.commit()except Exception as e:print(f"执行多个参数的sql语句时出错: {e}")# def call_stored_procedure(self, procedure_name, params):#     """#     调用存储过程#     """#     try:#         self.cursor.callproc(procedure_name, params)#         self.connection.commit()#     except Exception as e:#         print(f"调用存储过程时出错: {e}")def call_stored_procedure(self, procedure_name, params=None):"""调用存储过程"""try:if params:if self.driver == "ODBC Driver 17 for SQL Server":self.cursor.execute(f"EXEC {procedure_name} {','.join(['?' for _ in params])}", params)elif self.driver == "Oracle":self.cursor.callproc(procedure_name, params)else:if self.driver == "ODBC Driver 17 for SQL Server":self.cursor.execute(f"EXEC {procedure_name}")elif self.driver == "Oracle":self.cursor.callproc(procedure_name)self.connection.commit()except Exception as e:print(f"调用存储过程时出错: {e}")def __del__(self):"""关闭连接"""try:if self.cursor:self.cursor.close()if self.connection:self.connection.close()except Exception as e:self.cursor.close()self.connection.close()print(f"关闭连接时出错: {e}")def read_sql_file(file_path):"""读取sql文件D:\Desktop\待办sql.sql文件格式为文本文件,包含SQL查询语句,每条语句以分号结尾:param file_path::return:"""try:with open(file_path, 'r') as f:sql = f.read()# print(sql)return sqlexcept Exception as e:print(f"读取SQL文件时出错: {e}")

这篇关于python dbUtil的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/991440

相关文章

Python函数的基本用法、返回值特性、全局变量修改及异常处理技巧

《Python函数的基本用法、返回值特性、全局变量修改及异常处理技巧》本文将通过实际代码示例,深入讲解Python函数的基本用法、返回值特性、全局变量修改以及异常处理技巧,感兴趣的朋友跟随小编一起看看... 目录一、python函数定义与调用1.1 基本函数定义1.2 函数调用二、函数返回值详解2.1 有返

Python Excel 通用筛选函数的实现

《PythonExcel通用筛选函数的实现》本文主要介绍了PythonExcel通用筛选函数的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录案例目的示例数据假定数据来源是字典优化:通用CSV数据处理函数使用说明使用示例注意事项案例目的第一

Python实现中文大写金额转阿拉伯数字

《Python实现中文大写金额转阿拉伯数字》在财务票据中,中文大写金额被广泛使用以防止篡改,但在数据处理时,我们需要将其转换为阿拉伯数字形式,下面我们就来看看如何使用Python实现这一转换吧... 目录一、核心思路拆解二、中文数字解析实现三、大单位分割策略四、元角分综合处理五、测试验证六、全部代码在财务票

使用python制作一款文件粉碎工具

《使用python制作一款文件粉碎工具》这篇文章主要为大家详细介绍了如何使用python制作一款文件粉碎工具,能够有效粉碎密码文件和机密Excel表格等,感兴趣的小伙伴可以了解一下... 文件粉碎工具:适用于粉碎密码文件和机密的escel表格等等,主要作用就是防止 别人用数据恢复大师把你刚删除的机密的文件恢

在.NET项目中嵌入Python代码的实践指南

《在.NET项目中嵌入Python代码的实践指南》在现代开发中,.NET与Python的协作需求日益增长,从机器学习模型集成到科学计算,从脚本自动化到数据分析,然而,传统的解决方案(如HTTPAPI或... 目录一、CSnakes vs python.NET:为何选择 CSnakes?二、环境准备:从 Py

python中getsizeof和asizeof的区别小结

《python中getsizeof和asizeof的区别小结》本文详细的介绍了getsizeof和asizeof的区别,这两个函数都用于获取对象的内存占用大小,它们来自不同的库,下面就来详细的介绍一下... 目录sys.getsizeof (python 内置)pympler.asizeof.asizeof

Python的Darts库实现时间序列预测

《Python的Darts库实现时间序列预测》Darts一个集统计、机器学习与深度学习模型于一体的Python时间序列预测库,本文主要介绍了Python的Darts库实现时间序列预测,感兴趣的可以了解... 目录目录一、什么是 Darts?二、安装与基本配置安装 Darts导入基础模块三、时间序列数据结构与

Python正则表达式匹配和替换的操作指南

《Python正则表达式匹配和替换的操作指南》正则表达式是处理文本的强大工具,Python通过re模块提供了完整的正则表达式功能,本文将通过代码示例详细介绍Python中的正则匹配和替换操作,需要的朋... 目录基础语法导入re模块基本元字符常用匹配方法1. re.match() - 从字符串开头匹配2.

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

通过Docker容器部署Python环境的全流程

《通过Docker容器部署Python环境的全流程》在现代化开发流程中,Docker因其轻量化、环境隔离和跨平台一致性的特性,已成为部署Python应用的标准工具,本文将详细演示如何通过Docker容... 目录引言一、docker与python的协同优势二、核心步骤详解三、进阶配置技巧四、生产环境最佳实践