python实现和mysql一起实现数据库的增删改查

要在 Python 中使用 MySQL 数据库进行增删改查(CRUD)操作,你可以使用 `pymysql` 库。以下是一些示例代码,展示如何实现这些操作。

首先,确保你已经安装了 `pymysql`。如果没有安装,可以通过以下命令安装:

```bash

pip install pymysql

```

1. 连接数据库

```python

import pymysql

连接数据库

conn = pymysql.connect(host='localhost', user='your_username', password='your_password', db='your_db', charset='utf8mb4')

```

2. 创建(Create)

```python

创建游标对象

cursor = conn.cursor()

插入数据

sql = "INSERT INTO patient (name, age, time) VALUES (%s, %s, %s)"

try:

cursor.execute(sql, ('John Doe', 30, '2024-07-27 10:00:00'))

conn.commit() # 提交事务

except pymysql.Error as e:

print(e)

conn.rollback() # 回滚事务

关闭游标和连接

cursor.close()

conn.close()

```

3. 读取(Read)

```python

创建游标对象

cursor = conn.cursor(pymysql.cursors.DictCursor)

查询所有数据

sql = "SELECT * FROM patient"

try:

cursor.execute(sql)

results = cursor.fetchall()

for row in results:

print(row)

except pymysql.Error as e:

print(e)

关闭游标和连接

cursor.close()

conn.close()

```

4. 更新(Update)

```python

创建游标对象

cursor = conn.cursor()

更新数据

sql = "UPDATE patient SET age = %s WHERE name = %s"

try:

cursor.execute(sql, (31, 'John Doe'))

conn.commit() # 提交事务

except pymysql.Error as e:

print(e)

conn.rollback() # 回滚事务

关闭游标和连接

cursor.close()

conn.close()

```

5. 删除(Delete)

```python

创建游标对象

cursor = conn.cursor()

删除数据

sql = "DELETE FROM patient WHERE name = %s"

try:

cursor.execute(sql, ('John Doe',))

conn.commit() # 提交事务

except pymysql.Error as e:

print(e)

conn.rollback() # 回滚事务

关闭游标和连接

cursor.close()

conn.close()

```

完整示例

```python

import pymysql

连接数据库

conn = pymysql.connect(host='localhost', user='your_username', password='your_password', db='your_db', charset='utf8mb4')

创建游标对象

cursor = conn.cursor()

插入数据

sql_insert = "INSERT INTO patient (name, age, time) VALUES (%s, %s, %s)"

try:

cursor.execute(sql_insert, ('John Doe', 30, '2024-07-27 10:00:00'))

conn.commit()

except pymysql.Error as e:

print(e)

conn.rollback()

查询数据

sql_select = "SELECT * FROM patient"

try:

cursor.execute(sql_select)

results = cursor.fetchall()

for row in results:

print(row)

except pymysql.Error as e:

print(e)

更新数据

sql_update = "UPDATE patient SET age = %s WHERE name = %s"

try:

cursor.execute(sql_update, (31, 'John Doe'))

conn.commit()

except pymysql.Error as e:

print(e)

conn.rollback()

删除数据

sql_delete = "DELETE FROM patient WHERE name = %s"

try:

cursor.execute(sql_delete, ('John Doe',))

conn.commit()

except pymysql.Error as e:

print(e)

conn.rollback()

关闭游标和连接

cursor.close()

conn.close()

```

确保替换 `your_username`, `your_password`, `your_db` 为你的 MySQL 数据库的实际用户名、密码和数据库名。同时,确保你的数据库服务器正在运行,并且你有足够的权限执行这些操作。

相关推荐
Microsoft Word3 小时前
向量数据库与RAG
数据库·人工智能·向量数据库·rag
艾德金的溪4 小时前
redis-7.4.6部署安装
前端·数据库·redis·缓存
小光学长4 小时前
基于Vue的2025年哈尔滨亚冬会志愿者管理系统5zqg6m36(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
前端·数据库·vue.js
我的offer在哪里5 小时前
Redis
数据库·redis·缓存
点灯小铭5 小时前
基于单片机的多模式自动洗衣机设计与实现
数据库·单片机·嵌入式硬件·毕业设计·课程设计
潜心编码5 小时前
基于python的仓库管理系统
数据库
herinspace5 小时前
如何设置电脑分辨率和显示缩放
服务器·数据库·智能手机·电脑
biubiubiu07065 小时前
Ubuntu中定时任务测试
数据库·postgresql
程序新视界6 小时前
在MySQL中,一条SQL语句的执行全流程是怎样的?
数据库·后端·mysql