Python轻量级NoSQL数据库TinyDB

https://github.com/msiemens/tinydb

TinyDB 是一个纯 Python 实现的嵌入式 NoSQL 数据库,适用于存储小型数据集合,尤其适合用于轻量级应用、个人项目或原型开发。

一、安装

python 复制代码
pip install tinydb

二.基本操作

1.创建和初始化数据库

python 复制代码
from tinydb import TinyDB

# 创建一个数据库(文件名为 db.json)
db = TinyDB('db.json')

2. 插入数据

TinyDB 支持字典格式的数据插入。可以使用 insertinsert_multiple 方法来插入单条或多条数据。

python 复制代码
# 插入单条数据
db.insert({'name': 'Alice', 'age': 30})

# 插入多条数据
db.insert_multiple([
    {'name': 'Bob', 'age': 25},
    {'name': 'Charlie', 'age': 35}
])
json 复制代码
{
    "_default": {
        "1": {
            "name": "Alice",
            "age": 30
        },
        "2": {
            "name": "Bob",
            "age": 25
        },
        "3": {
            "name": "Charlie",
            "age": 35
        }
    }
}

3. 查询数据

查询通过 Query 类来构建查询条件。

python 复制代码
from tinydb import Query

# 创建一个查询对象
User = Query()

# 查询 name 为 Alice 的记录
result = db.search(User.name == 'Alice')

# 查询 age 大于 30 的记录
result = db.search(User.age > 30)

print(result)

4. 更新数据

你可以使用 update 方法来更新数据。更新操作是基于查询结果执行的。

python 复制代码
# 更新 Alice 的年龄为 31
db.update({'age': 31}, User.name == 'Alice')

# 批量更新
db.update({'age': 40}, User.age < 30)

5. 删除数据

删除数据的操作也非常简单,可以使用 remove 方法删除符合条件的记录。

python 复制代码
# 删除 name 为 Bob 的记录
db.remove(User.name == 'Bob')

# 删除所有 age 小于 30 的记录
db.remove(User.age < 30)

6. 排序和分页

TinyDB 提供了基本的排序功能。可以使用 order_by 方法来对查询结果进行排序:

python 复制代码
# 按年龄升序排序
result = db.all()  # 获取所有记录
sorted_result = sorted(result, key=lambda x: x['age'])

print(sorted_result)

7. 数据库备份和恢复

TinyDB 数据库是存储在 JSON 文件中的,可以很容易地备份或恢复。只需要简单的复制文件即可实现。

python 复制代码
import shutil

# 备份数据库
shutil.copy('db.json', 'db_backup.json')

# 恢复数据库
shutil.copy('db_backup.json', 'db.json')

三、高级使用

1. 使用不同的存储方案

TinyDB 支持多种存储方案,默认使用的是 JSONStorage。你还可以使用 MemoryStorage 来改变数据的存储方式。

python 复制代码
from tinydb.storages import JSONStorage

# 使用默认存储
db = TinyDB('db.json', storage=JSONStorage)

2. 支持嵌套数据

TinyDB 支持存储嵌套的数据结构,可以是字典、列表等。例如:

python 复制代码
db.insert({
    'name': 'David',
    'address': {
        'city': 'New York',
        'zip': '10001'
    }
})

你可以通过查询嵌套字段进行过滤:

python 复制代码
result = db.search(User.address['city'] == 'New York')

3. 使用 Index

TinyDB 也支持为字段创建索引,从而加速查询。使用索引时,可以显著提高查询性能,特别是当数据量增加时。

python 复制代码
# 创建索引
db.create_index(['name'])

# 查询时使用索引
result = db.search(User.name == 'Alice')

总结

TinyDB 在单线程环境中非常轻便和易用,但在多线程环境下需要特别小心。使用线程锁来保证每次只有一个线程对数据库进行操作,是避免数据冲突和写入混乱的关键。在并发较低的小型项目中,TinyDB 依然是一个不错的选择,但如果并发要求较高,建议考虑使用其他数据库系统。

相关推荐
冷雨夜中漫步8 小时前
Python快速入门(6)——for/if/while语句
开发语言·经验分享·笔记·python
郝学胜-神的一滴8 小时前
深入解析Python字典的继承关系:从abc模块看设计之美
网络·数据结构·python·程序人生
百锦再8 小时前
Reactive编程入门:Project Reactor 深度指南
前端·javascript·python·react.js·django·前端框架·reactjs
m0_7369191010 小时前
C++代码风格检查工具
开发语言·c++·算法
喵手10 小时前
Python爬虫实战:旅游数据采集实战 - 携程&去哪儿酒店机票价格监控完整方案(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·采集结果csv导出·旅游数据采集·携程/去哪儿酒店机票价格监控
2501_9449347310 小时前
高职大数据技术专业,CDA和Python认证优先考哪个?
大数据·开发语言·python
helloworldandy10 小时前
使用Pandas进行数据分析:从数据清洗到可视化
jvm·数据库·python
黎雁·泠崖10 小时前
【魔法森林冒险】5/14 Allen类(三):任务进度与状态管理
java·开发语言
2301_7634724611 小时前
C++20概念(Concepts)入门指南
开发语言·c++·算法
肖永威11 小时前
macOS环境安装/卸载python实践笔记
笔记·python·macos