概念 - 查询数据库和页面提供有限的属性

Posted

技术标签:

【中文标题】概念 - 查询数据库和页面提供有限的属性【英文标题】:Notion - Querying databases and pages provide limited properties 【发布时间】:2021-08-27 00:10:59 【问题描述】:

我正在尝试通过 REST API 访问我的 Notion 中的单个数据库。

在 Notion 中查询或列出我的数据库时,我只收到了预期属性的一个子集。

在我访问的数据库中有 23 个属性,您可以在最后一个屏幕截图中看到。 所以有 7 个没有出现,因为我在调用 LIST DB REST API(第一个屏幕截图)时看到了 16 个。 知道为什么这 7 个属性没有显示吗?

   class Test:
    def __init__(self):
        self.notion = None
        self.databases = 
        self.pageIds = []
        self.pages = 

    def initialize(self):
        #NOTION_TOKEN = os.getenv("NOTION_TOKEN", "")
        with open('Notion_Config.YAML') as f:
            data = yaml.load(f, Loader=yaml.FullLoader)
            print(data)
        NOTION_TOKEN = data["Token"]

        while NOTION_TOKEN == "":
            print("NOTION_TOKEN not found.")
            NOTION_TOKEN = input("Enter your integration token: ").strip()

        self.notion = Client(auth=NOTION_TOKEN)

    def list_db(self):
        results = self.notion.databases.list()
        print("Listing databases: ")
        for item in results["results"]:
            print(item["title"][0]["plain_text"])
            self.databases.update(item["title"][0]["plain_text"] : item["id"])

    def query_db(self, database_name):
        #while db["more"] == True:
        db = self.notion.databases.query(database_id=self.databases.get(database_name))
        for item in db["results"]:
            print(item)
            self.pageIds.append(item["id"])

    def query_pages(self):
        for item in self.pageIds:
            page = self.notion.pages.retrieve(page_id=item)
            print(page)

调用 list_db。可以看到检索到的属性数是 16

调用 query_db。您可以看到为第一页检索到的属性数为 14

此屏幕截图显示了我的数据库的属性列表

【问题讨论】:

【参考方案1】:

在概念中显示数据库属性的最终屏幕截图有 6 个箭头。这 6 个属性表示指向数据库的关系属性。

相关项目 购物清单 取决于(任务) 相关人员/公司 资源 子任务

这些关系属性中有 2 个是自关系,这意味着它们指向它们所在的同一个数据库。

子任务 依赖于(任务)

对 Notion REST API 的调用只能访问您已授予权限的数据库。由于您只提供了对这个单一数据库的访问权限,因此您应该只看到自关系属性。

放大镜 代表公式属性。如果任何公式属性使用您的 Notion API 集成无权访问的关系属性,那么您也将无法看到这些。

项目状态 购买状态 费用

在数据库中查询页面时,您可能只会收到页面具有非空值的属性。

【讨论】:

以上是关于概念 - 查询数据库和页面提供有限的属性的主要内容,如果未能解决你的问题,请参考以下文章

在 Firebase 中查询有限的数据

数据分析 - 子查询

lucene:初始(概念创建索引执行查询分析器)

翻译:关系操作

数据库查询

知了堂学习笔记JSP页面数据分页实现——分页概念以及主流数据库的分页查询