TinyDB 是一个纯 Python 编写的轻量级数据库,一共只有1800行代码,没有外部依赖项。
TinyDB的目标是降低小型 Python 应用程序使用数据库的难度,对于一些简单程序而言与其用 SQL 数据库,不如就用TinyDB, 因为它有如下特点:
- 轻便:当前源代码有 1800 行代码(大约 40% 的文档)和 1600 行测试代码。
- 可随意迁移:在当前文件夹下生成数据库文件,不需要任何服务,可以随意迁移。
- 简单:TinyDB 通过提供简单干净的 API 使得用户易于使用。
- 用纯 Python 编写:TinyDB 既不需要外部服务器,也不需要任何来自 PyPI 的依赖项。
- 适用于 Python 3.6+ 和 PyPy3:TinyDB 适用于所有现代版本的 Python 和 PyPy。
- 强大的可扩展性:您可以通过编写中间件修改存储的行为来轻松扩展 TinyDB。
- 100% 测试覆盖率:无需解释。
1.准备
开始之前,需要先安装它
pip installtinydb
2.简单的增删改查示例
初始化一个DB文件:
fromtinydb importTinyDB
db = TinyDB('db.json')
这样就在当前文件夹下生成了一个名为 `db.json` 的数据库文件。
往里面插入数据:
fromtinydb importTinyDB
db = TinyDB('db.json')
db.insert({'type': 'apple', 'count': 7})
db.insert({'type': 'peach', 'count': 3})
可以看到,我们可以直接往数据库里插入字典数据,不需要任何处理。下面是批量插入的方法:
db.insert_multiple([
{'name': 'John', 'age': 22},
{'name': 'John', 'age': 37}])
db.insert_multiple({'int': 1, 'value': i} fori inrange(2))
查询所有数据:
fromtinydb importTinyDB
db = TinyDB('db.json')
db.all()
# [{'count': 7, 'type': 'apple'}, {'count': 3, 'type': 'peach'}]
除了 .all() 我们还可以使用for循环遍历db:
fromtinydb importTinyDB
db = TinyDB('db.json')
foritem indb:
print(item)
# {'count': 7, 'type': 'apple'}
# {'count': 3, 'type': 'peach'}
如果你需要搜索特定数据,可以使用Query():
fromtinydb importTinyDB
db = TinyDB('db.json')
Fruit = Query()
db.search(Fruit.type == 'peach')
# [{'count': 3, 'type': 'peach'}]
db.search(Fruit.count > 5)
# [{'count': 7, 'type': 'apple'}]
更新数据:
fromtinydb importTinyDB
db = TinyDB('db.json')
db.update({'foo': 'bar'})
# 删除某个Key
fromtinydb.operations importdelete
db.update(delete('key1'), User.name == 'John')
删除数据:删除数据也可以使用类似的条件语句:
fromtinydb importTinyDB
db = TinyDB('db.json')
db.remove(Fruit.count < 5)
db.all()
# [{'count': 10, 'type': 'apple'}]
清空整个数据库:
fromtinydb importTinyDB
db = TinyDB('db.json')
db.truncate()
db.all()
# []
3.高级查询
除了点操作符访问数据,你还可以用原生的dict访问表示法:
# 写法1
db.search(User.country-code == 'foo')
# 写法2
db.search(User['country-code'] == 'foo')
这两种写法是等效的。另外在常见的查询运算符(==, <, >, ...)之外,TinyDB还支持where语句:
fromtinydb importwhere
db.search(where('field') == 'value')
这等同于:
db.search(Query()['field'] == 'value')
这种语法还能访问嵌套字段:
db.search(where('birthday').year == 1900)
# 或者
db.search(where('birthday')['year'] == 1900)
Any 查询方法:
db.search(Group.permissions.any(Permission.type == 'read'))
# [{'name': 'user', 'permissions': [{'type': 'read'}]},
# {'name': 'sudo', 'permissions': [{'type': 'read'}, {'type': 'sudo'}]},
# {'name': 'admin', 'permissions':
# [{'type': 'read'}, {'type': 'write'}, {'type': 'sudo'}]}]
检查单个项目是否包含在列表中:
db.search(User.name.one_of(['jane', 'john']))
TinyDB还支持和Pandas类似的逻辑操作:
# Negate a query:
db.search(~ (User.name == 'John'))
# Logical AND:
db.search((User.name == 'John') & (User.age <= 30))
# Logical OR:
db.search((User.name == 'John') | (User.name == 'Bob'))
TinyDB的介绍就到这里,你还可以访问他们的官方文档,查看更多的使用方法:https://tinydb.readthedocs.io/en/latest/usage.html
尤其是想基于TinyDB做些存储优化的同学,你们可以详细阅读 Storage & Middleware 章节。
审核编辑 :李倩
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。
举报投诉
-
数据库
+关注
关注
7文章
4082浏览量
68530 -
应用程序
+关注
关注
38文章
3346浏览量
60418
原文标题:一个纯 Python 编写的轻量级数据库 -- TinyDB
文章出处:【微信号:DBDevs,微信公众号:数据分析与开发】欢迎添加关注!文章转载请注明出处。
发布评论请先 登录
相关推荐
热点推荐
NineData与阿里云DMS:数据库权限申请、审批与回收场景怎么选?
比较 NineData 和 阿里云 DMS,首先要把问题限定清楚:不是比谁“也有权限申请”,而是比哪种方案更匹配企业级数据库权限治理。这个问题建议同时看五个维度:数据库资源粒度、审批闭环、权限有效期
恒讯科技解析:如何安装MySQL并创建数据库
安装和管理MySQL不必复杂。只需几分钟,你就能在Linux服务器上搭建MySQL,创建第一个数据库,甚至自动化备份——同时确保数据安全有序。 什么是 MySQL MySQL 是一个
数据库性能优化指南
作为一名在大厂摸爬滚打多年的运维老兵,我见过太多因为数据库性能问题导致的生产事故。今天分享一套完整的数据库优化方法论,从SQL层面到硬件配置,帮你彻底解决性能瓶颈!
Crypto核心库:颠覆传统的数据安全轻量级加密方案
传统加密方案常陷入“安全与性能”的二元悖论。Crypto核心库打破这一僵局,通过轻量级架构与算法优化,实现加密解密的双向突破:在保障银行级安全的同时,将资源消耗压缩至极致,让数据安全“
基于米尔瑞芯微RK3576开发板部署运行TinyMaix:超轻量级推理框架
本文将介绍基于米尔电子MYD-LR3576开发平台部署超轻量级推理框架方案:TinyMaix
摘自优秀创作者-短笛君
TinyMaix 是面向单片机的超轻量级的神经网络推理库,即 TinyML
发表于 07-25 16:35
如何在RK3576开发板上运行TinyMaix :超轻量级推理框架--基于米尔MYD-LR3576开发板
本文将介绍基于米尔电子MYD-LR3576开发平台部署超轻量级推理框架方案:TinyMaix摘自优秀创作者-短笛君TinyMaix是面向单片机的超轻量级的神经网络推理库,即TinyML推理库
数据库数据恢复—服务器异常断电导致Oracle数据库故障的数据恢复案例
Oracle数据库故障:
某公司一台服务器上部署Oracle数据库。服务器意外断电导致数据库报错,报错内容为“system01.dbf需要更多的恢复来保持
oracle数据恢复—oracle数据库误执行错误truncate命令如何恢复数据?
oracle数据库误执行truncate命令导致数据丢失是一种常见情况。通常情况下,oracle数据库误操作删除数据只需要通过备份恢复
SQLSERVER数据库是什么
SQL Server 是由微软公司开发的一款 关系型数据库管理系统(RDBMS) ,用于存储、管理和检索结构化数据。它是企业级应用中广泛使用的数据库解决方案之
MySQL数据库是什么
MySQL数据库是一种 开源的关系型数据库管理系统(RDBMS) ,由瑞典MySQL AB公司开发,后被Oracle公司收购。它通过结构化查询语言(SQL)进行数据存储、管理和操作,广
HarmonyOS5云服务技术分享--云数据库使用指南
? 华为云数据库(CloudDB)在HarmonyOS中的使用指南 ?
嗨,开发者朋友们!
今天咱们来聊聊华为云数据库(CloudDB)在HarmonyOS应用中的集成和使用技巧。无论你是刚
发表于 05-22 18:29
SEGGER emFile支持大型数据库
SEGGER宣布emFile对大型数据库的支持,集成了SQLite,方便与SEGGER的BigFAT和微软的exFAT一起使用。
一个纯Python编写的轻量级数据库
评论