如何使用 Python 连接 SQLite 数据库?

server/2024/12/24 23:48:55/

SQLite是一种轻量级的嵌入式数据库,广泛应用于各种应用程序中。

Python提供了内置的sqlite3模块,使得连接和操作SQLite数据库变得非常简单。

下面我将详细介绍如何使用sqlite3模块来连接SQLite数据库,并提供一些实际开发中的建议和注意事项。

1. 使用 sqlite3 连接SQLite数据库

sqlite3 是Python标准库中的一个模块,无需额外安装即可使用。

连接数据库

下面是一个简单的示例,展示如何连接到SQLite数据库

import sqlite3# 创建数据库连接
conn = sqlite3.connect('example.db')# 创建游标对象
cur = conn.cursor()# 创建表
cur.execute('''CREATE TABLE IF NOT EXISTS users (id INTEGER PRIMARY KEY,name TEXT NOT NULL,email TEXT NOT NULL)''')# 插入数据
cur.execute("INSERT INTO users (name, email) VALUES (?, ?)", ('Alice', 'alice@example.com'))
cur.execute("INSERT INTO users (name, email) VALUES (?, ?)", ('Bob', 'bob@example.com'))# 提交事务
conn.commit()# 查询数据
cur.execute("SELECT * FROM users")
rows = cur.fetchall()for row in rows:print(row)# 关闭游标和连接
cur.close()
conn.close()
注意事项
  1. 错误处理:在实际开发中,应该添加错误处理机制,以防止数据库操作失败或其他异常情况。
import sqlite3try:conn = sqlite3.connect('example.db')cur = conn.cursor()cur.execute('''CREATE TABLE IF NOT EXISTS users (id INTEGER PRIMARY KEY,name TEXT NOT NULL,email TEXT NOT NULL)''')cur.execute("INSERT INTO users (name, email) VALUES (?, ?)", ('Alice', 'alice@example.com'))cur.execute("INSERT INTO users (name, email) VALUES (?, ?)", ('Bob', 'bob@example.com'))conn.commit()cur.execute("SELECT * FROM users")rows = cur.fetchall()for row in rows:print(row)
except sqlite3.Error as e:print(f"Error: {e}")
finally:if cur:cur.close()if conn:conn.close()
  1. 上下文管理器:为了确保资源被正确释放,可以使用上下文管理器(with语句)来管理数据库连接和游标。
import sqlite3try:with sqlite3.connect('example.db') as conn:with conn.cursor() as cur:cur.execute('''CREATE TABLE IF NOT EXISTS users (id INTEGER PRIMARY KEY,name TEXT NOT NULL,email TEXT NOT NULL)''')cur.execute("INSERT INTO users (name, email) VALUES (?, ?)", ('Alice', 'alice@example.com'))cur.execute("INSERT INTO users (name, email) VALUES (?, ?)", ('Bob', 'bob@example.com'))conn.commit()cur.execute("SELECT * FROM users")rows = cur.fetchall()for row in rows:print(row)
except sqlite3.Error as e:print(f"Error: {e}")
2. 使用参数化查询

为了避免SQL注入攻击,应该使用参数化查询。

import sqlite3try:with sqlite3.connect('example.db') as conn:with conn.cursor() as cur:cur.execute('''CREATE TABLE IF NOT EXISTS users (id INTEGER PRIMARY KEY,name TEXT NOT NULL,email TEXT NOT NULL)''')cur.execute("INSERT INTO users (name, email) VALUES (?, ?)", ('Alice', 'alice@example.com'))cur.execute("INSERT INTO users (name, email) VALUES (?, ?)", ('Bob', 'bob@example.com'))conn.commit()cur.execute("SELECT * FROM users WHERE name = ?", ('Alice',))rows = cur.fetchall()for row in rows:print(row)
except sqlite3.Error as e:print(f"Error: {e}")
3. 使用事务

SQLite支持事务操作,可以通过事务来确保数据的一致性和完整性。

import sqlite3try:with sqlite3.connect('example.db') as conn:with conn.cursor() as cur:cur.execute('''CREATE TABLE IF NOT EXISTS users (id INTEGER PRIMARY KEY,name TEXT NOT NULL,email TEXT NOT NULL)''')conn.execute("BEGIN TRANSACTION")try:cur.execute("INSERT INTO users (name, email) VALUES (?, ?)", ('Alice', 'alice@example.com'))cur.execute("INSERT INTO users (name, email) VALUES (?, ?)", ('Bob', 'bob@example.com'))conn.commit()except sqlite3.Error as e:conn.rollback()print(f"Error: {e}")cur.execute("SELECT * FROM users")rows = cur.fetchall()for row in rows:print(row)
except sqlite3.Error as e:print(f"Error: {e}")
实际开发中的建议
  1. 错误处理:始终添加错误处理机制,以确保在数据库操作失败时能够捕获并处理异常。
  2. 资源管理:使用上下文管理器来管理数据库连接和游标,确保资源被正确释放。
  3. 参数化查询:使用参数化查询来防止SQL注入攻击,确保数据库操作的安全性。
  4. 事务管理:合理使用事务来确保数据的一致性和完整性。
  5. 日志记录:在生产环境中,添加日志记录机制,以便在出现问题时能够追踪和调试。

在Python中连接SQLite数据库sqlite3 模块提供了一个简单且强大的接口。通过合理使用上下文管理器、参数化查询和事务管理,可以提高代码的健壮性和性能,确保数据库操作的安全性和可靠性。在实际开发中,应该注意错误处理、资源管理和日志记录,以确保系统的稳定性和可维护性。

通过这些方法和技巧,你可以有效地连接和管理SQLite数据库,满足各种复杂的需求。希望这些内容对你有所帮助,如果你有任何问题或需要进一步的讨论,请随时提问。


http://www.ppmy.cn/server/152903.html

相关文章

Oracle、ACCSEE与TDMS的区别

Oracle、ACCSEE和TDMS都是不同类型的数据管理和存储工具,它们各自有独特的用途、结构和复杂性。Oracle是一个功能强大的关系型数据库管理系统,适用于大规模企业级应用,支持复杂查询和事务管理。ACCSEE主要应用于实时数据采集和过程监控&#…

流年运势API接口_解析个人命理十年大运PHP实现方法返回json数据

介绍 流年运势与十年大运的 API 接口提供了一种高效的方式来分析个体的命理特征。通过输入个人的基本信息(包括姓、名、性别、出生日期和时间),用户可以获取详细的命理分析,包括五行数量、生肖、八字、十神、命宫等信息。这些数据…

OpenCV(python)从入门到精通——文件操作

图像的读取 import cv2 as cv 图片的读取if __name__ __main__:# 读取图片img cv.imread(r"images/1.jpg",cv.IMREAD_COLOR)# 显示图片cv.imshow("pic show",img)# 暂停cv.waitKey(0)不同读取方式,灰度图读取 import cv2 as cv 图片的读取if __name__ …

[AI]解释 Git 的基本概念和使用方式

Git 是一个版本控制系统,用于跟踪文件的更改并协调多个人的代码开发。它具有以下基本概念和使用方式: 1. 仓库(Repository):Git 仓库是存储代码和相关资料的地方。一个项目通常有一个主仓库,包含所有的版本…

基于Spring Boot的远程教育网站

一、系统背景与意义 随着互联网技术的飞速发展和普及,远程教育已成为现代教育体系中的重要组成部分。它打破了时间和空间的限制,让学习者可以随时随地进行学习。基于Spring Boot的远程教育网站正是为了满足这一需求而设计的,它利用互联网技术…

springboot 配置Kafka 关闭自启动连接

这里写自定义目录标题 springboot 配置Kafka 关闭自启动连接方法一:使用 ConditionalOnProperty方法二:手动管理Kafka监听器容器方法三:使用 autoStartupfalse结语 springboot 配置Kafka 关闭自启动连接 在Spring Boot应用程序中&#xff0c…

《VQ-VAE》:Stable Diffusion设计的架构源泉

文章目录 阅读本文你可以了解到1 VQ-VAE的核心思想1.1 为什么VQ-VAE想要把图像编码成离散向量?1.2 VQ-VAE引入codebook(即embedding space嵌入空间)1.3 VQ-VAE的工作过程 2 VQ-VAE实现方法2.1 VQ-VAE的编码器怎么输出离散向量。2.2 VQ-VAE怎么优化编码器…

Certifying LLM Safety against Adversarial Prompting

erase-and-check erase:逐一删除prompt中的词元(token) check:用安全过滤器检查生成的子序列。 如果任何子序列或输入提示本身被过滤器检测为有害,则将该提示标记为有害。 如图,对有对抗性后缀的有害pr…