Python操作SQLite3数据库实战:连接、查询、插入、更新、删除与关闭
139 浏览量
更新于2024-08-31
收藏 74KB PDF 举报
"本文将详细讲解Python开发SQLite3数据库的相关操作,包括连接、查询、插入、更新、删除和关闭数据库的技巧。SQLite是一款轻量级的嵌入式数据库,Python的sqlite3模块提供了与SQLite交互的接口。我们将通过示例代码来阐述如何使用这些操作。"
在Python中,SQLite3数据库的使用首先需要建立连接。如果指定的数据库文件不存在,`sqlite3.connect()`方法会自动创建。例如,连接到硬盘上的数据库文件可以这样写:
```python
conn = sqlite3.connect('c:\\test\\hongten.db')
```
连接对象(conn)提供了几个关键方法:
- `commit()`:用于提交事务,保存对数据库的修改。
- `rollback()`:如果发生错误,可以回滚事务,撤销未保存的更改。
- `close()`:关闭数据库连接,释放资源。
- `cursor()`:创建一个游标对象,用于执行SQL命令。
游标对象(如`cu = conn.cursor()`)是执行SQL语句的核心。它有以下方法:
- `execute(sql)`:执行单条SQL语句。
- `executemany(sql, params_list)`:批量执行多条相同的SQL语句,参数列表包含不同的数据。
- `close()`:关闭游标,释放内存。
- `fetchone()`:获取查询结果集中的一条记录。
- `fetchmany(size)`:获取size条记录,如果结果集小于size,则返回所有剩余记录。
- `fetchall()`:获取结果集中所有记录。
- `scroll(offset, mode='relative')`:移动游标的位置,mode可选为'relative'(相对位置)或'absolute'(绝对位置)。
下面是一个简单的示例,展示了如何使用Python操作SQLite3数据库:
```python
import sqlite3
# 连接到数据库
conn = sqlite3.connect('example.db')
# 创建游标
cur = conn.cursor()
# 创建表
cur.execute('''CREATE TABLE users
(id INTEGER PRIMARY KEY, name TEXT, email TEXT)''')
# 插入数据
cur.execute("INSERT INTO users VALUES (1, 'Alice', 'alice@example.com')")
cur.execute("INSERT INTO users VALUES (2, 'Bob', 'bob@example.com')")
# 提交事务
conn.commit()
# 查询数据
cur.execute("SELECT * FROM users")
print(cur.fetchall())
# 关闭游标和连接
cur.close()
conn.close()
```
在这个例子中,我们创建了一个名为`users`的表,插入了两条记录,并打印了所有用户的信息。最后,确保游标和连接都被正确关闭,以释放系统资源。
总结起来,Python的sqlite3模块提供了简单而强大的接口,允许开发者轻松地进行数据库操作。无论是初次接触数据库编程,还是在小型项目中快速存储和检索数据,SQLite3都是一个理想的选择。通过学习和实践这些基本操作,你可以高效地管理SQLite数据库并与之交互。
2020-09-09 上传
2016-04-24 上传
点击了解资源详情
2020-09-08 上传
2020-09-09 上传
点击了解资源详情
点击了解资源详情
点击了解资源详情
2020-09-09 上传
weixin_38682790
- 粉丝: 3
- 资源: 978
最新资源
- SSM动力电池数据管理系统源码及数据库详解
- R语言桑基图绘制与SCI图输入文件代码分析
- Linux下Sakagari Hurricane翻译工作:cpktools的使用教程
- prettybench: 让 Go 基准测试结果更易读
- Python官方文档查询库,提升开发效率与时间节约
- 基于Django的Python就业系统毕设源码
- 高并发下的SpringBoot与Nginx+Redis会话共享解决方案
- 构建问答游戏:Node.js与Express.js实战教程
- MATLAB在旅行商问题中的应用与优化方法研究
- OMAPL138 DSP平台UPP接口编程实践
- 杰克逊维尔非营利地基工程的VMS项目介绍
- 宠物猫企业网站模板PHP源码下载
- 52简易计算器源码解析与下载指南
- 探索Node.js v6.2.1 - 事件驱动的高性能Web服务器环境
- 找回WinSCP密码的神器:winscppasswd工具介绍
- xctools:解析Xcode命令行工具输出的Ruby库