python连接mysql数据库通用类

在 Python 中创建一个通用的数据库连接类,用于连接 MySQL 数据库并执行常见的数据库操作,可以提高代码的复用性和可维护性。下面是一个示例:

```python

import mysql.connector

class MySQLDatabase:

def init(self, host, user, password, database):

self.host = host

self.user = user

self.password = password

self.database = database

self.connection = None

self.cursor = None

def connect(self):

try:

self.connection = mysql.connector.connect(

host=self.host,

user=self.user,

password=self.password,

database=self.database

)

self.cursor = self.connection.cursor()

print("Connected to MySQL database")

except mysql.connector.Error as error:

print(f"Error connecting to MySQL database: {error}")

def execute_query(self, query):

try:

self.cursor.execute(query)

self.connection.commit()

print("Query executed successfully")

except mysql.connector.Error as error:

print(f"Error executing query: {error}")

def fetch_query(self, query):

try:

self.cursor.execute(query)

rows = self.cursor.fetchall()

return rows

except mysql.connector.Error as error:

print(f"Error fetching data: {error}")

return None

def close_connection(self):

if self.connection.is_connected():

self.cursor.close()

self.connection.close()

print("MySQL connection closed")

Example of usage:

if name == "main":

Initialize MySQLDatabase object

db = MySQLDatabase(host="your_host",

user="your_username",

password="your_password",

database="your_database_name")

Connect to the database

db.connect()

Example query execution

create_table_query = """

CREATE TABLE IF NOT EXISTS users (

id INT AUTO_INCREMENT PRIMARY KEY,

username VARCHAR(50) NOT NULL,

email VARCHAR(100) NOT NULL

)

"""

db.execute_query(create_table_query)

Example data insertion

insert_query = """

INSERT INTO users (username, email)

VALUES ('john_doe', 'john@example.com')

"""

db.execute_query(insert_query)

Example data retrieval

select_query = "SELECT * FROM users"

rows = db.fetch_query(select_query)

if rows:

for row in rows:

print(row)

Close the database connection

db.close_connection()

```

在这个示例中:

  • `MySQLDatabase` 类封装了 MySQL 数据库的连接和常用操作,包括连接、执行查询、执行插入操作以及关闭连接。

  • `init` 方法用于初始化数据库连接参数。

  • `connect` 方法用于建立数据库连接。

  • `execute_query` 方法用于执行 SQL 查询或更新操作。

  • `fetch_query` 方法用于执行查询并获取结果集。

  • `close_connection` 方法用于关闭数据库连接。

根据自己的需求扩展这个类,添加更多的数据库操作方法或错误处理机制。记得替换示例中的 `your_host`、`your_username`、`your_password` 和 `your_database_name` 为实际的数据库连接信息。

相关推荐
小陈工10 小时前
Python Web开发入门(十七):Vue.js与Python后端集成——让前后端真正“握手言和“
开发语言·前端·javascript·数据库·vue.js·人工智能·python
0xDevNull14 小时前
MySQL数据冷热分离详解
后端·mysql
A__tao14 小时前
Elasticsearch Mapping 一键生成 Java 实体类(支持嵌套 + 自动过滤注释)
java·python·elasticsearch
研究点啥好呢15 小时前
Github热门项目推荐 | 创建你的像素风格!
c++·python·node.js·github·开源软件
科技小花15 小时前
数据治理平台架构演进观察:AI原生设计如何重构企业数据管理范式
数据库·重构·架构·数据治理·ai-native·ai原生
一江寒逸15 小时前
零基础从入门到精通MySQL(中篇):进阶篇——吃透多表查询、事务核心与高级特性,搞定复杂业务SQL
数据库·sql·mysql
D4c-lovetrain15 小时前
linux个人心得22 (mysql)
数据库·mysql
迷藏49415 小时前
**发散创新:基于Rust实现的开源合规权限管理框架设计与实践**在现代软件架构中,**权限控制(RBAC)** 已成为保障
java·开发语言·python·rust·开源
明日清晨15 小时前
python扫码登录dy
开发语言·python
阿里小阿希15 小时前
CentOS7 PostgreSQL 9.2 升级到 15 完整教程
数据库·postgresql