Skip to main content

🥭 Async MongoDB ODM with type hints in Python

Project description

Mango

Mango

🥭 带有类型提示的 Python 异步 MongoDB 对象文档映射器

license pypi python

查看演示 · 错误报告 · 功能请求

简体中文 · English · 日本語

🔖 目录

目录

📖 简介

Mango 是一个带有类型提示的 Python 异步 MongoDB 对象文档映射器(ODM),它构建在 MotorPydantic 之上。

Mango 使得数据建模和查询变得非常容易,帮助您关注应用程序中真正重要的部分。

✨ 核心特性:

  • 完善的类型标注:利用静态分析来减少运行时问题
  • 简洁流畅的 API:更易于学习和使用,提高开发效率
  • 优雅的编辑器支持:自动完成无处不在,从对象创建到查询结果

[⬆回到顶部]

🚀 安装

PIP

pip install mango-odm

Poetry

poetry add mango-odm

[⬆回到顶部]

🌟 示例

import asyncio

from mango import Document, EmbeddedDocument, Field, Mango


# 嵌入式文档
class Author(EmbeddedDocument):
    name: str
    profile: str | None = None


# Mango 文档模型
class Book(Document):
    name: str = Field(primary_key=True)  # 将字段设置为主键,如果不显式指定主键,则会自动创建 id 字段作为主键
    summary: str | None = None
    author: Author  # 嵌入文档
    price: int = Field(index=True)  # 为字段添加索引


async def main():
    # 初始化 Mango,它会创建连接并初始化文档模型,你可以传入 db 或者 uri 参数来指定连接
    await Mango.init()

    # 像 pydantic 的模型一样使用
    book = Book(name="book", author=Author(name="author"), price=10)
    # 将它插入到数据库中
    await book.save()

    # Mango 提供了丰富的查询语言,允许您使用 Python 表达式来查询
    if book := await Book.find(Book.price <= 20, Book.author.name == "author").get():
        # 更新文档的 summary 字段
        book.summary = "summary"
        await book.update()


if __name__ == "__main__":
    asyncio.run(main())

[⬆回到顶部]

🤝 贡献

想为这个项目做出一份贡献吗?点击这里阅读并了解如何贡献。

🎉 鸣谢

感谢以下开发者对该项目做出的贡献:

[⬆回到顶部]

💖 支持

喜欢这个项目?请点亮 star 并分享它!

[⬆回到顶部]

📝 许可证

MIT 许可证下分发。请参阅 LICENSE 以获取更多信息。

[⬆回到顶部]

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mango_odm-0.4.1.tar.gz (21.8 kB view details)

Uploaded Source

Built Distribution

mango_odm-0.4.1-py3-none-any.whl (24.4 kB view details)

Uploaded Python 3

File details

Details for the file mango_odm-0.4.1.tar.gz.

File metadata

  • Download URL: mango_odm-0.4.1.tar.gz
  • Upload date:
  • Size: 21.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.12.3

File hashes

Hashes for mango_odm-0.4.1.tar.gz
Algorithm Hash digest
SHA256 abf69848496b6bcc7c69ad01963d79d20f1f955f8c8751bd0a9147655619291e
MD5 edc4b536bbcab30e7f1337233f234bdf
BLAKE2b-256 70e24d17a46b284e0bbf90a276213f5a1e63351e0b01ca12b9e56dec89295ee0

See more details on using hashes here.

File details

Details for the file mango_odm-0.4.1-py3-none-any.whl.

File metadata

  • Download URL: mango_odm-0.4.1-py3-none-any.whl
  • Upload date:
  • Size: 24.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.12.3

File hashes

Hashes for mango_odm-0.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 762885a66992bd7c2109be845c1c161d2166dc85032d437545763f1233e0fa3a
MD5 1cd17a6c3f83e6cd48522c33767e83a5
BLAKE2b-256 f6de6b075442099b44f4b801f4663607876afc69d4defd8a8ec8a003ffb56a18

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page