如何使用Python操作SQLite?轻量数据库教程

python 操作 sqlite 数据库的步骤如下:1. 使用 sqlite3.connect() 连接数据库并创建文件;2. 通过 cursor 执行 sql 创建数据表;3. 使用参数化查询插入、更新、删除数据;4. 用 select 查询记录并处理结果;5. 操作完成后调用 commit() 提交更改并关闭连接。整个过程无需额外安装依赖,适合小型项目和本地开发。

如何使用Python操作SQLite?轻量数据库教程

SQLite 是一种轻量级的嵌入式数据库,非常适合小型项目、本地开发或者作为移动应用的数据存储。Python 内置了对 SQLite 的支持,所以不需要额外安装驱动或依赖库就可以直接使用。

如何使用Python操作SQLite?轻量数据库教程

下面我们就来看看怎么用 Python 操作 SQLite 数据库。

如何使用Python操作SQLite?轻量数据库教程

连接数据库和创建表

首先,我们需要连接到一个数据库文件。如果这个文件不存在,Python 会自动帮我们创建一个新的。

立即学习“Python免费学习笔记(深入)”;

import sqlite3conn = sqlite3.connect('example.db')

接下来,我们可以通过 cursor 对象来执行 SQL 语句,比如创建一张表:

如何使用Python操作SQLite?轻量数据库教程

cursor = conn.cursor()cursor.execute('''    CREATE TABLE IF NOT EXISTS users (        id INTEGER PRIMARY KEY AUTOINCREMENT,        name TEXT NOT NULL,        age INTEGER    )''')conn.commit()

上面这段代码做了几件事:

创建了一个名为 users 的表(如果已经存在就不会重复创建)定义了三个字段:自增主键 id、非空字符串 name、整数 age最后调用了 commit() 提交更改

别忘了操作完成后关闭连接:

conn.close()

插入数据和查询结果

插入数据可以用 INSERT INTO 语句,这里建议使用参数化查询来防止 SQL 注入:

cursor.execute("INSERT INTO users (name, age) VALUES (?, ?)", ("Alice", 25))conn.commit()

查询也很简单,例如查找所有用户:

cursor.execute("SELECT * FROM users")rows = cursor.fetchall()for row in rows:    print(row)

如果你只想查一条记录,可以使用 fetchone()

row = cursor.fetchone()print(row)

记得每次执行完查询或修改后都要检查是否需要调用 commit(),尤其是涉及写操作时。

更新和删除数据

更新数据使用 UPDATE 语句,同样推荐使用参数绑定:

cursor.execute("UPDATE users SET age = ? WHERE name = ?", (30, "Alice"))conn.commit()

删除数据使用 DELETE 语句:

cursor.execute("DELETE FROM users WHERE name = ?", ("Alice",))conn.commit()

这两个操作都会修改数据库内容,所以一定要记得调用 commit(),否则不会生效。

小贴士和注意事项

数据库连接要关闭:虽然 Python 在程序结束时会自动关闭连接,但最好手动调用 conn.close(),避免资源泄露。

使用上下文管理器更安全:可以用 with 来自动提交事务或回滚错误。

with sqlite3.connect('example.db') as conn:    cursor = conn.cursor()    cursor.execute("INSERT INTO users (name, age) VALUES (?, ?)", ("Bob", 22))

字段类型灵活:SQLite 是弱类型的,即使你定义了字段为 INTEGER,也可以存字符串进去,但不建议这么做,容易出错。

适合小规模数据:SQLite 不适合高并发写的场景,但读操作表现还不错。

基本上就这些。SQLite 简单好用,适合快速搭建原型或者做本地工具的数据存储,配合 Python 基本上不需要太多配置就能开始用了。

以上就是如何使用Python操作SQLite?轻量数据库教程的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1362777.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月14日 03:02:58
下一篇 2025年12月14日 03:03:12

相关推荐

  • 如何用Python开发网络嗅探器?Scapy实战

    使用scapy开发网络嗅探器的核心步骤包括:1. 导入scapy库并定义数据包处理函数;2. 使用sniff函数捕获流量并传递给回调函数;3. 在回调函数中解析ip、tcp、raw等层级信息。scapy的优势在于其灵活性和强大的协议支持,不仅能捕获数据包,还可构造、发送和修改数据包,适用于网络安全测…

    2025年12月14日 好文分享
    000
  • 如何用Python实现代码生成?模板引擎方案

    模板引擎是python代码生成的首选方案,因其能实现结构与数据的分离。1. 它通过定义一次代码骨架并用不同数据填充,提升效率和一致性;2. 模板如蓝图般清晰可读,使用变量和控制流语法(如{{ var_name }}、{% if %})动态生成内容;3. 工作流程包括定义模板、准备数据、加载模板、渲染…

    2025年12月14日 好文分享
    000
  • Python怎样处理非结构化数据—文本/图像特征提取

    处理非结构化数据的关键在于特征提取。针对文本,常用方法包括词袋模型、tf-idf、词嵌入,并可用sklearn、gensim等库实现;对于图像,传统方法如hog、sift结合深度学习cnn模型如resnet可提取有效特征;实战中需注意数据清洗、归一化及降维处理。python提供了强大的工具支持,使这…

    2025年12月14日 好文分享
    000
  • Python中如何操作SVG图像?svgwrite库指南

    使用svgwrite绘制和组合基本svg图形的方法包括:1. 创建drawing对象定义画布;2. 使用add方法添加圆形、矩形、线段、椭圆、多边形、折线等基本图形;3. 利用g元素对图形进行分组和变换以实现复杂结构。通过这些步骤,可以灵活地构建并组织svg内容,提升代码可读性和可维护性。 在Pyt…

    2025年12月14日 好文分享
    000
  • Python中如何使用协程?async/await详解

    协程是python中通过async/await语法实现的异步编程机制,其本质是一种轻量级线程,由程序员控制切换,相比多线程更节省资源、切换开销更小,适合处理大量并发i/o操作。1. 协程函数通过async def定义,调用后返回协程对象,需放入事件循环中执行;2. 使用await等待协程或异步操作完…

    2025年12月14日 好文分享
    000
  • 怎样用Python处理时区转换—pytz时区处理方案

    如何用pytz处理时区转换?1. 安装并导入pytz,使用pip install pytz,并通过from datetime import datetime和import pytz导入模块;2. 创建带有时区信息的时间,使用pytz.timezone()获取时区对象并通过datetime.now()…

    2025年12月14日 好文分享
    000
  • Python中的类变量和实例变量有什么区别?深度解析!

    类变量和实例变量的主要区别在于归属和生命周期。1. 类变量属于类本身,所有实例共享同一份类变量;2. 实例变量属于每个实例,独立存在。类变量定义在类范围内,用于存储与类整体相关的状态;实例变量通常在__init__方法中定义,通过self访问。访问类变量可通过类名或实例,但通过实例修改会创建同名实例…

    2025年12月14日 好文分享
    000
  • Python如何处理医学影像?SimpleITK教程

    python处理医学影像的核心在于使用simpleitk库,1. 安装simpleitk:pip install simpleitk;2. 读取影像:支持dicom、nifti等格式,并可获取图像信息如大小和像素类型;3. 转换为numpy数组进行像素访问,注意坐标顺序差异;4. 提供多种图像处理操…

    2025年12月14日 好文分享
    000
  • Python中如何操作Selenium?自动化浏览器测试方法

    python中操作selenium的核心是通过webdriver接口模拟用户行为,实现自动化测试和数据抓取。1. 安装selenium库并配置浏览器驱动;2. 使用webdriver启动浏览器并访问页面;3. 通过多种方式定位元素并进行交互;4. 推荐使用显式等待提高效率;5. 可管理多个窗口、调整…

    2025年12月14日 好文分享
    000
  • Python中如何实现边缘检测?OpenCV算法详解

    canny边缘检测是图像处理中的常用选择,因为它在准确性与鲁棒性之间取得了良好平衡。其优势包括:①对噪声的抵抗力强,通过高斯模糊有效去除干扰;②边缘定位精确,非极大值抑制确保单像素宽的边缘;③能连接断裂边缘,双阈值滞后处理机制提升边缘完整性;④综合性能好,兼顾效果与计算效率。这些特性使canny广泛…

    2025年12月14日 好文分享
    000
  • Python如何实现网页截图?selenium使用教程

    使用 selenium 实现网页截图的最常用方法是安装库和对应浏览器驱动,通过代码控制浏览器进行截图。步骤如下:1. 安装 selenium 并下载对应的浏览器驱动(如 chromedriver);2. 编写代码打开浏览器、访问网址并保存截图;3. 若遇到驱动路径或加载问题,应检查驱动版本与路径设置…

    2025年12月14日 好文分享
    000
  • 如何使用Python处理日志?logging模块配置

    python处理日志的核心工具是其内置的logging模块,它提供了一套全面且高度可配置的日志管理框架。logging模块包含四个核心组件:logger负责产生日志;handler决定日志输出位置;formatter定义日志格式;filter控制日志内容过滤。相比print语句,logging支持多…

    2025年12月14日 好文分享
    000
  • Python如何连接Kafka?kafka-python配置指南

    python连接kafka最推荐使用kafka-python库,其核心类为kafkaproducer和kafkaconsumer。1. kafkaproducer用于消息生产,关键参数包括bootstrap_servers(指定kafka地址)、value_serializer/key_serial…

    2025年12月14日 好文分享
    000
  • Python如何实现多线程编程?threading模块使用详解

    python中使用threading模块进行多线程编程,1.通过创建thread对象并调用start()启动线程;2.使用target指定执行函数,args/kwargs传参;3.join()方法可使主线程等待子线程结束;4.设置daemon=true可将线程设为守护线程;5.使用lock解决资源共…

    2025年12月14日 好文分享
    000
  • 怎样用Python处理音频?pydub基础教程

    用python处理音频的首选工具是pydub,1. 安装pydub:pip install pydub;2. 安装ffmpeg并配置环境变量,windows需手动下载并添加路径,macos用homebrew安装,linux用包管理器;3. 加载音频文件,支持mp3、wav、ogg等格式;4. 支持剪…

    2025年12月14日 好文分享
    000
  • 怎样用Python实现强化学习?OpenAI Gym入门

    强化学习通过试错调整策略,使程序在环境中学会完成任务。核心步骤包括:1.安装openai gym环境,使用pip命令安装基础包或扩展包;2.创建环境如cartpole,调用gym.make并重置状态;3.与环境交互,随机或基于策略选择动作,执行后获取反馈;4.应用q-learning算法训练agen…

    2025年12月14日 好文分享
    000
  • Python如何实现数据聚类?sklearn机器学习案例

    数据聚类是无监督学习方法,用于发现数据中的自然分组,常用工具是python的scikit-learn库。1. 常见算法包括kmeans(适合球形分布)、dbscan(基于密度、可识别噪声)、agglomerative clustering(层次结构)和gmm(概率模型)。2. 使用kmeans步骤:…

    2025年12月14日 好文分享
    000
  • 如何用Python制作GUI界面?tkinter基础入门

    tkinter是python标准库中的gui工具包,适合快速开发简单界面。1. 创建主窗口:使用tk.tk()初始化窗口并设置标题和大小;2. 添加控件:如label、entry和button,并通过pack()布局管理器排列;3. 启动事件循环:调用mainloop()保持窗口显示并响应用户操作。…

    2025年12月14日 好文分享
    000
  • 解决Hugging Face LoRA微调中load_in_8bit的ImportError:依赖版本兼容性指南

    本文旨在解决在使用Hugging Face transformers库进行LoRA微调时,因启用load_in_8bit=True而引发的ImportError,该错误通常指向accelerate和bitsandbytes库的兼容性问题。文章将深入分析错误成因,并提供一套经过验证的、兼容的库版本配置…

    2025年12月14日
    000
  • 解决Python pdfbox库初始化时导致Python解释器退出的问题

    本文旨在解决在使用Python pdfbox库时,由于环境配置或兼容性问题导致Python解释器意外退出的问题。我们将深入探讨可能的原因,并提供一系列排查和解决步骤,包括Java版本兼容性检查、库安装验证、Classpath配置、错误处理以及Java路径配置,帮助读者顺利使用pdfbox库进行PDF…

    2025年12月14日
    000

发表回复

登录后才能评论
关注微信