news 2026/6/13 1:12:50

SQLite 入门指南:在 Python 中轻松操作数据库

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
SQLite 入门指南:在 Python 中轻松操作数据库

引言

如果你刚开始学习编程或数据存储,可能会觉得数据库听起来有点“高大上”。但实际上,使用数据库可以非常轻松,尤其是当你选择了 SQLite —— 一个轻量、易用、功能强大的嵌入式数据库。

本博客将带你从零开始,学习如何使用 Python 操作 SQLite 数据库,并通过一个实际案例展示如何基于 FastAPI 构建一个简单的 CRUD API。

一.什么是 SQLite?

SQLite 是一个基于 C 语言开发的轻量级 SQL 数据库引擎。它不需要独立的服务器,整个数据库就存储在一个文件中,非常适合小型项目、移动应用或学习使用。

1.1 SQLite 的特点:

轻量级:无需安装,直接使用

易于学习:语法与标准 SQL 非常相似

高性能:对于中小型数据操作非常快

跨平台:支持 Windows、macOS、Linux

二.Python 操作 SQLite 数据库

Python 自带 sqlite3 模块,无需额外安装。下面我们一步步学习如何操作。

2.1准备工作

import sqlite3

2.2 创建数据库和表

conn = sqlite3.connect('students.db') cur = conn.cursor() cur.execute(''' CREATE TABLE IF NOT EXISTS students ( id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT NOT NULL, age INTEGER, grade TEXT ) ''') conn.commit() conn.close()

2.3 插入数据

conn = sqlite3.connect('students.db') cur = conn.cursor() cur.execute("INSERT INTO students (name, age, grade) VALUES (?, ?, ?)", ('Alice', 20, 'A')) cur.execute("INSERT INTO students (name, age, grade) VALUES (?, ?, ?)", ('Bob', 22, 'B')) conn.commit() conn.close()

2.4查询数据

conn = sqlite3.connect('students.db') cur = conn.cursor() cur.execute("SELECT * FROM students") rows = cur.fetchall() for row in rows: print(row) conn.close()

2.5 更新与删除数据

conn = sqlite3.connect('students.db') cur = conn.cursor() # 更新数据 cur.execute("UPDATE students SET grade = ? WHERE name = ?", ('A+', 'Bob')) # 删除数据 cur.execute("DELETE FROM students WHERE name = ?", ('Bob',)) conn.commit() conn.close()

更新:

删除:

三.练习(多练习加深印象)

创建 books.db 数据库,建立 books 表,字段包括 id、title、author、year

插入三条书籍数据

import sqlite3 # 连接到数据库(如果不存在会自动创建) conn = sqlite3.connect('books.db') cursor = conn.cursor() # 创建 books 表 cursor.execute(''' CREATE TABLE IF NOT EXISTS books ( id INTEGER PRIMARY KEY AUTOINCREMENT, title TEXT NOT NULL, author TEXT NOT NULL, year INTEGER ) ''') # 插入三条书籍数据 books_data = [ ('The Great Gatsby', 'F. Scott Fitzgerald', 1925), ('To Kill a Mockingbird', 'Harper Lee', 1960), ('1984', 'George Orwell', 1949) ] cursor.executemany('INSERT INTO books (title, author, year) VALUES (?, ?, ?)', books_data) # 提交事务 conn.commit() # 查询并显示插入的数据 print("已插入的数据:") cursor.execute('SELECT * FROM books') for row in cursor.fetchall(): print(f"ID: {row[0]}, 书名: {row[1]}, 作者: {row[2]}, 年份: {row[3]}") # 关闭连接 conn.close()

四.总结

SQLite 是一个非常友好的数据库入门选择,搭配 Python 的 sqlite3 模块,你可以轻松实现数据的存储与管理。通过函数和面向对象封装,代码会更易维护。而使用 FastAPI + SQLAlchemy 则可以构建出功能完整、结构清晰的 Web API。

如果你对数据库操作还不熟悉,建议从简单的 SQLite 开始,逐步过渡到更复杂的应用场景。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/12 11:35:47

使用Dify智能体平台集成Qwen3-8B构建企业级知识问答系统

使用Dify智能体平台集成Qwen3-8B构建企业级知识问答系统 在企业数字化转型不断深入的今天,员工每天面对的信息量呈指数级增长——从内部制度、项目文档到产品手册,知识分散且查找困难。与此同时,客户对服务响应速度和准确性的要求越来越高。传…

作者头像 李华
网站建设 2026/6/12 12:22:40

LeetCode 2110.股票平滑下跌阶段的数目:数学(一次遍历)

【LetMeFly】2110.股票平滑下跌阶段的数目:数学(一次遍历) 力扣题目链接:https://leetcode.cn/problems/number-of-smooth-descent-periods-of-a-stock/ 给你一个整数数组 prices ,表示一支股票的历史每日股价&#…

作者头像 李华
网站建设 2026/6/12 12:31:43

智慧树学习助手:3分钟完成自动化学习配置的完整指南

智慧树学习助手:3分钟完成自动化学习配置的完整指南 【免费下载链接】zhihuishu 智慧树刷课插件,自动播放下一集、1.5倍速度、无声 项目地址: https://gitcode.com/gh_mirrors/zh/zhihuishu 还在为智慧树平台的冗长视频课程烦恼吗?手动…

作者头像 李华
网站建设 2026/6/12 11:26:40

Windows虚拟显示器完整教程:免费扩展你的数字工作空间

Windows虚拟显示器完整教程:免费扩展你的数字工作空间 【免费下载链接】virtual-display-rs A Windows virtual display driver to add multiple virtual monitors to your PC! For Win10. Works with VR, obs, streaming software, etc 项目地址: https://gitcod…

作者头像 李华
网站建设 2026/6/12 20:06:28

Vue3低代码开发平台:3步搭建你的首个可视化应用

Vue3低代码开发平台:3步搭建你的首个可视化应用 【免费下载链接】vite-vue3-lowcode vue3.x vite2.x vant element-plus H5移动端低代码平台 lowcode 可视化拖拽 可视化编辑器 visual editor 类似易企秀的H5制作、建站工具、可视化搭建工具 项目地址: https://…

作者头像 李华