Python面试题:在 Python 中,如何连接并操作数据库?

在 Python 中,可以使用多种库来连接并操作数据库。常用的库有 sqlite3psycopg2(用于 PostgreSQL)、PyMySQL(用于 MySQL)、SQLAlchemy(一个 ORM 工具,支持多种数据库)。下面以 SQLite 和 MySQL 为例,介绍如何连接并操作数据库。

使用 sqlite3 库操作 SQLite 数据库

  1. 连接数据库
python 复制代码
import sqlite3

# 连接到 SQLite 数据库(如果数据库不存在,会自动创建)
conn = sqlite3.connect('example.db')

# 创建游标对象
cursor = conn.cursor()
  1. 创建表
python 复制代码
# 创建表
cursor.execute('''CREATE TABLE IF NOT EXISTS users
                  (id INTEGER PRIMARY KEY AUTOINCREMENT,
                   name TEXT NOT NULL,
                   age INTEGER NOT NULL)''')
  1. 插入数据
python 复制代码
# 插入数据
cursor.execute("INSERT INTO users (name, age) VALUES ('Alice', 30)")
cursor.execute("INSERT INTO users (name, age) VALUES ('Bob', 25)")

# 提交事务
conn.commit()
  1. 查询数据
python 复制代码
# 查询数据
cursor.execute("SELECT * FROM users")
rows = cursor.fetchall()

for row in rows:
    print(row)
  1. 更新数据
python 复制代码
# 更新数据
cursor.execute("UPDATE users SET age = 26 WHERE name = 'Bob'")

# 提交事务
conn.commit()
  1. 删除数据
python 复制代码
# 删除数据
cursor.execute("DELETE FROM users WHERE name = 'Alice'")

# 提交事务
conn.commit()
  1. 关闭连接
python 复制代码
# 关闭游标和连接
cursor.close()
conn.close()

使用 PyMySQL 库操作 MySQL 数据库

  1. 安装 PyMySQL
sh 复制代码
pip install pymysql
  1. 连接数据库
python 复制代码
import pymysql

# 连接到 MySQL 数据库
conn = pymysql.connect(
    host='localhost',
    user='yourusername',
    password='yourpassword',
    database='yourdatabase'
)

# 创建游标对象
cursor = conn.cursor()
  1. 创建表
python 复制代码
# 创建表
cursor.execute('''CREATE TABLE IF NOT EXISTS users
                  (id INT AUTO_INCREMENT PRIMARY KEY,
                   name VARCHAR(255) NOT NULL,
                   age INT NOT NULL)''')
  1. 插入数据
python 复制代码
# 插入数据
cursor.execute("INSERT INTO users (name, age) VALUES ('Alice', 30)")
cursor.execute("INSERT INTO users (name, age) VALUES ('Bob', 25)")

# 提交事务
conn.commit()
  1. 查询数据
python 复制代码
# 查询数据
cursor.execute("SELECT * FROM users")
rows = cursor.fetchall()

for row in rows:
    print(row)
  1. 更新数据
python 复制代码
# 更新数据
cursor.execute("UPDATE users SET age = 26 WHERE name = 'Bob'")

# 提交事务
conn.commit()
  1. 删除数据
python 复制代码
# 删除数据
cursor.execute("DELETE FROM users WHERE name = 'Alice'")

# 提交事务
conn.commit()
  1. 关闭连接
python 复制代码
# 关闭游标和连接
cursor.close()
conn.close()

使用 SQLAlchemy 库操作数据库

  1. 安装 SQLAlchemy
sh 复制代码
pip install sqlalchemy
  1. 连接数据库
python 复制代码
from sqlalchemy import create_engine, Column, Integer, String
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import sessionmaker

# 创建数据库引擎
engine = create_engine('sqlite:///example.db', echo=True)

# 创建基类
Base = declarative_base()

# 定义数据表
class User(Base):
    __tablename__ = 'users'
    id = Column(Integer, primary_key=True, autoincrement=True)
    name = Column(String)
    age = Column(Integer)

# 创建数据表
Base.metadata.create_all(engine)

# 创建会话
Session = sessionmaker(bind=engine)
session = Session()
  1. 插入数据
python 复制代码
# 插入数据
new_user = User(name='Alice', age=30)
session.add(new_user)
session.commit()
  1. 查询数据
python 复制代码
# 查询数据
users = session.query(User).all()
for user in users:
    print(user.name, user.age)
  1. 更新数据
python 复制代码
# 更新数据
user = session.query(User).filter_by(name='Alice').first()
user.age = 31
session.commit()
  1. 删除数据
python 复制代码
# 删除数据
user = session.query(User).filter_by(name='Alice').first()
session.delete(user)
session.commit()

这三个示例展示了如何使用 sqlite3PyMySQLSQLAlchemy 库连接并操作数据库。根据具体需求和数据库类型,可以选择合适的库来实现数据库操作。

相关推荐
yuanyuan2o2几秒前
你可能需要的算法思想——动态规划
数据结构·python·算法·动态规划
寰宇的行者2 分钟前
深入理解 Django 异步视图中的 `sync_to_async` 与协程
数据库·django
Thomas.Sir3 分钟前
第七章:RAG知识库开发之【RAG开源应用完全解析:从RAGFlow到Dify的实战指南】
人工智能·python·开源·fastgpt·dify·ragflow
deephub5 分钟前
不依赖对话日志检测Prompt注入,一套隐私优先的实现方案
人工智能·python·prompt·大语言模型
草莓熊Lotso5 分钟前
MySQL 索引特性与性能优化全解
android·运维·数据库·c++·mysql·性能优化
薛定谔的悦10 分钟前
站控显示下级从控EMS的版本信息开发(设计多线程和TCP通讯)
linux·网络·数据库·网络协议·tcp/ip·ems
郝学胜-神的一滴11 分钟前
张量维度操控心法:从reshape到升维降维,吃透PyTorch形状操作的底层逻辑
人工智能·pytorch·python·深度学习·程序人生·算法·机器学习
bcbobo21cn13 分钟前
C#使用一维数组作为参数传递
开发语言·数据库·c#·一维数组
Zzzzmo_15 分钟前
【JavaEE】多线程01
java·jvm·java-ee·多线程
荒川之神16 分钟前
Hive 拉链表实例
开发语言·数据库