Anytype——思源数据库的指路明灯

本贴最后更新于 229 天前,其中的信息可能已经时移世易

anytype 的介绍可以看这个视频:【Notion 要跌下神坛了?采用去中心化技术的类 Notion 笔记工具 Anytype,保护用户隐私且支援离线使用!-哔哩哔哩】 https://b23.tv/Tbpr0s5

这两天又重新上手摸了下 anytype,对 anytype 的自由奔放的数据库十分喜欢,来和大家分享分享、说道说道,盘一盘页面、属性和数据库的三角关系,重点只在于三角关系,notion 的 formula 啥的不在讨论范围内。

先吐槽一下 anytype,TMD 非要给自己的各种功能起个特立独行的名字,增加上手成本,就不能用些普罗大众已经习以为常的名词吗!我先用广为人知的 notion 以及诸位都在用的 siyuan 来辨析一下 anytype 里的名词和功能:

页面 属性 数据库
notion block,块 page,页面 property,属性 database,数据库
anytype block,块 object,对象
relation,关联 set,集合
siyuan block,块
document,文档
attribute,属性 database,数据库

notion、anytype 和思源的最小粒度都是块,不过 notion 和 anytype 的块只是纯粹的内容载体,并不能被赋予属性,而思源的属性能够触及到块粒度,点个赞 👍

anytype 的页面比较有意思,不叫页面,叫 object,因为按照 anytype 的使用哲学,每个页面都要强制分类到某一个 type,是骡是马,还是阿猫阿狗,都行,随便,但一定要分类!在 anytype 里新建页面就和我们现在丢垃圾一样要面临一个难题:这是什么垃圾?就问你烦不烦!当然也可以眼不见心不烦,不管有几个桶,我就只看到一个黑色的垃圾桶,我就把你一股脑儿丢到 page 里,怎么滴吧!这叫重器轻用!

有人不禁就要问了:为什么啊?为什么啊!为什么一定要分类啊!!

这就不得不说 anytype 的另一个要点了:每个页面都要有属性,必须有属性!这样才能搞些其他软件没有的骚操作。有了属性就能够根据属性来进行汇总、筛选、建立页面的联系了!一个 type 就是把一些属性绑在一起做成了一个预设,任君选用。页面有了属性,在码农的眼里,不是 object 还能是什么?

anytype:诸位看官,你看,你只要把小手这么一点这个阿猫 set,所有的阿猫就都在你的面前了。再一点这个阿狗 set,所有的阿狗随便挑了!除了我,还有谁能这么简单、这么轻松、这么随随便便就能做到?!NB 不 NB?!

其他软件:是是是,你最牛逼!我们都做不到!也就您,一上来就给用户霸王硬上弓搞垃圾分类,这天下啊,非您莫属啦 🫶

吐槽归吐槽,anytype 在搞三角关系上还是有两把刷子的!我们来看看 notion、anytype 和 siyuan 在数据库功能上的差异:

一个页面可以添加到多个数据库 不同数据库共享页面属性 数据库能够自动汇总符合条件的页面 数据库当做多维表使用
notion X X X X
anytype X
siyuan X X

开山祖师爷 notion 在上面的对比中不堪一击,干啥啥不行,要啥啥没有。这是由设计思路的差异决定的。notion 的数据库可以当做一种特殊的页面,你能够在 notion 的文档树中找到所有的数据库,数据库的每一行都是一个子页面,数据库是展现子文档的一种特殊方式。

而 anytype 和思源的数据库是独立于文档存在的。anytype 的数据库是文档属性的特殊展示方式和组合方式。思源的数据库是属性的特殊展示方式,甚至不需要文档的参与,但并不能对文档的属性进行任意组合。

  • 从自由度上来说,notion<siyuan<anytype。

    • 在 notion 中,文档属于数据库,属性也属于数据库,他们都依托于数据库而存在(在当前语境中,请忽略那些不属于数据库的、没有属性的文档)。

    • siyuan 在 notion 的基础上将数据库与文档解耦,属性虽然仍属于数据库,但文档已独立于数据库存在,文档可以自由选择加入哪些数据库、获得哪些数据库的属性。由于属性属于数据库,因此不同数据库之间的同名属性并不共享数据,加入多个数据库后文档的属性数量会急速膨胀。

    • anytype 最有魄力,不仅将文档从数据库中解放了出来,甚至将属性也从数据库中解放了。数据库、文档、属性是相互独立的个体,它们都属于工作空间,这是 anytype 数据库自由度高的根源。

      • 不同数据库可以从工作空间获得同一条属性,这些数据库将共享这条属性,在一个数据库中对其进行修改,该属性在其他数据库中也会相应变化。
      • 一个文档即使不加入数据库也能直接从工作空间获得属性,要多少有多少,没有就自己编一个。
      • 当一个文档和一个数据库拥有了相同的属性,这个文档就会自动加入这个数据库。
      • 简直完美!这就是我想要的思源数据库!
      • anytype 的属性虽然从概念上是独立于文档的,但脱离文档的属性也只是一个抽象概念,要化虚为实、有具体的值,还是要和文档相结合。

这时候可能有人要跳出来说了:瞎了你的狗眼,思源的属性也不是都属于数据库的,每个块还有自己的自定义属性呢!

你说的对!我完全赞同这个说法!D 大为什么要在块属性之外又搞了一套数据库属性啊!gun!直接用块属性的话至少能实现不同的数据库共享属性啊!再加把油给数据库加上 SQL 查询功能不就连自动汇总页面的功能都实现了吗!把 anytype 的底裤都脱掉!还有 anytype 什么事!

以上就是我心目中理想的数据库,和大家分享到这里。


@88250 最后提个需求:赶紧做个数据库管理面板吧!

notion 的数据库能够在文档树找到,anytype 的数据库能够在侧边栏的 Sets 组件找到,siyuan 的数据库只能去 av 文件夹里找,这可不得行,被人看到了毁我清白 👻 把文件夹名称改成学习资料也好啊trollface

  • Anytype
    3 引用 • 31 回帖 • 1 关注
  • 思源笔记

    思源笔记是一款隐私优先的个人知识管理系统,支持完全离线使用,同时也支持端到端加密同步。

    融合块、大纲和双向链接,重构你的思维。

    23014 引用 • 92572 回帖
1 操作
qiancang 在 2024-05-06 21:36:20 更新了该帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • aleegreat

    认同你观点

    1. 改善块/文档的自定义属性,支持方便的编辑、查看
    2. 支持 SQL 查询块/文档的属性,并灵活展示

    这样就能完全替代现在这套数据库功能,还比现在灵活

  • 其他回帖
  • 直接用块属性的话至少能实现不同的数据库共享属性啊!再加把油给数据库加上 SQL 查询功能不就连自动汇总页面的功能都实现了吗

    这个确实是好思路,就是估计还是两者合并起来相当于重构底层了

    另外支持做个数据库管理面板,哪怕能做个展示页面列出来也可以,这样就不用靠文档树点进文档里找了,毕竟思源数据库是与文档分家的,有个单独的管理页面应该会很方便

  • fradeet 1 评论

    Anytype 实际上就是把以前的的链接关系都统一成了“基于对象自身的关系”,数据量越大这种记录优势越明显。反正软件现在还是半成品,建议持续关注。 :)

    感觉思源的数据库如果基于块属性的话其实也可以做到这个。
    3Woods
  • Feline

    我也这么觉得。思源本来的块属性就很好了,相当于全局块属性,非常灵活。就是只支持字符类型,编辑起来也非常不方便,如果能像数据库中的列类型(日期、多选、关联……)那样丰富且便于编辑就好了。

    之前有插件可以编辑文档块的属性,支持多选和日期等类型,但不能编辑正文内的块属性。

    ❤️ 按块属性来查询符合条件的内容,生成数据库(可编辑,支持日期、多选、关联、模板公式等多种类型),就不用逐一为块添加至数据库了。
    😂 换一种思路描述就是:一个块可以添加各种类型的属性,这些属性是固定的,和块绑定的,可以被多个不同的数据库根据需要调用某些属性。

    现在一个块也可以添加到多个数据库,但是明明列属性内容是一样的,却需要重复在每个数据库里都添加一遍。
    举个列子,比如我有一篇介绍《诗经》这本书的文档,既想要添加到【个人书架】数据库,又想添加到【古诗词阅读】数据库。两个数据库,都需要添加 作者出版社 等列属性。
    对于《诗经》这个文档块而言,作者出版社 应该是它的块属性。

    目前 obsidian 已经有插件,可以实现根据文档属性生成数据库了(画廊视图),不过还不支持块级属性筛选。

    1 回复
  • 查看全部回帖

推荐标签 标签

  • Spark

    Spark 是 UC Berkeley AMP lab 所开源的类 Hadoop MapReduce 的通用并行框架。Spark 拥有 Hadoop MapReduce 所具有的优点;但不同于 MapReduce 的是 Job 中间输出结果可以保存在内存中,从而不再需要读写 HDFS,因此 Spark 能更好地适用于数据挖掘与机器学习等需要迭代的 MapReduce 的算法。

    74 引用 • 46 回帖 • 559 关注
  • 百度

    百度(Nasdaq:BIDU)是全球最大的中文搜索引擎、最大的中文网站。2000 年 1 月由李彦宏创立于北京中关村,致力于向人们提供“简单,可依赖”的信息获取方式。“百度”二字源于中国宋朝词人辛弃疾的《青玉案·元夕》词句“众里寻他千百度”,象征着百度对中文信息检索技术的执著追求。

    63 引用 • 785 回帖 • 164 关注
  • 微软

    微软是一家美国跨国科技公司,也是世界 PC 软件开发的先导,由比尔·盖茨与保罗·艾伦创办于 1975 年,公司总部设立在华盛顿州的雷德蒙德(Redmond,邻近西雅图)。以研发、制造、授权和提供广泛的电脑软件服务业务为主。

    8 引用 • 44 回帖
  • 友情链接

    确认过眼神后的灵魂连接,站在链在!

    24 引用 • 373 回帖
  • Caddy

    Caddy 是一款默认自动启用 HTTPS 的 HTTP/2 Web 服务器。

    12 引用 • 54 回帖 • 159 关注
  • Postman

    Postman 是一款简单好用的 HTTP API 调试工具。

    4 引用 • 3 回帖 • 7 关注
  • 电影

    这是一个不能说的秘密。

    121 引用 • 604 回帖 • 1 关注
  • 微服务

    微服务架构是一种架构模式,它提倡将单一应用划分成一组小的服务。服务之间互相协调,互相配合,为用户提供最终价值。每个服务运行在独立的进程中。服务于服务之间才用轻量级的通信机制互相沟通。每个服务都围绕着具体业务构建,能够被独立的部署。

    96 引用 • 155 回帖
  • FreeMarker

    FreeMarker 是一款好用且功能强大的 Java 模版引擎。

    23 引用 • 20 回帖 • 464 关注
  • Swift

    Swift 是苹果于 2014 年 WWDC(苹果开发者大会)发布的开发语言,可与 Objective-C 共同运行于 Mac OS 和 iOS 平台,用于搭建基于苹果平台的应用程序。

    36 引用 • 37 回帖 • 535 关注
  • ReactiveX

    ReactiveX 是一个专注于异步编程与控制可观察数据(或者事件)流的 API。它组合了观察者模式,迭代器模式和函数式编程的优秀思想。

    1 引用 • 2 回帖 • 161 关注
  • CongSec

    本标签主要用于分享网络空间安全专业的学习笔记

    1 引用 • 1 回帖 • 15 关注
  • 大数据

    大数据(big data)是指无法在一定时间范围内用常规软件工具进行捕捉、管理和处理的数据集合,是需要新处理模式才能具有更强的决策力、洞察发现力和流程优化能力的海量、高增长率和多样化的信息资产。

    93 引用 • 113 回帖
  • NetBeans

    NetBeans 是一个始于 1997 年的 Xelfi 计划,本身是捷克布拉格查理大学的数学及物理学院的学生计划。此计划延伸而成立了一家公司进而发展这个商用版本的 NetBeans IDE,直到 1999 年 Sun 买下此公司。Sun 于次年(2000 年)六月将 NetBeans IDE 开源,直到现在 NetBeans 的社群依然持续增长。

    78 引用 • 102 回帖 • 683 关注
  • TextBundle

    TextBundle 文件格式旨在应用程序之间交换 Markdown 或 Fountain 之类的纯文本文件时,提供更无缝的用户体验。

    1 引用 • 2 回帖 • 53 关注
  • 工具

    子曰:“工欲善其事,必先利其器。”

    288 引用 • 734 回帖 • 2 关注
  • Unity

    Unity 是由 Unity Technologies 开发的一个让开发者可以轻松创建诸如 2D、3D 多平台的综合型游戏开发工具,是一个全面整合的专业游戏引擎。

    25 引用 • 7 回帖 • 159 关注
  • Rust

    Rust 是一门赋予每个人构建可靠且高效软件能力的语言。Rust 由 Mozilla 开发,最早发布于 2014 年 9 月。

    58 引用 • 22 回帖
  • 负能量

    上帝为你关上了一扇门,然后就去睡觉了....努力不一定能成功,但不努力一定很轻松 (° ー °〃)

    88 引用 • 1235 回帖 • 410 关注
  • Pipe

    Pipe 是一款小而美的开源博客平台。Pipe 有着非常活跃的社区,可将文章作为帖子推送到社区,来自社区的回帖将作为博客评论进行联动(具体细节请浏览 B3log 构思 - 分布式社区网络)。

    这是一种全新的网络社区体验,让热爱记录和分享的你不再感到孤单!

    132 引用 • 1114 回帖 • 125 关注
  • 持续集成

    持续集成(Continuous Integration)是一种软件开发实践,即团队开发成员经常集成他们的工作,通过每个成员每天至少集成一次,也就意味着每天可能会发生多次集成。每次集成都通过自动化的构建(包括编译,发布,自动化测试)来验证,从而尽早地发现集成错误。

    15 引用 • 7 回帖
  • Bug

    Bug 本意是指臭虫、缺陷、损坏、犯贫、窃听器、小虫等。现在人们把在程序中一些缺陷或问题统称为 bug(漏洞)。

    76 引用 • 1737 回帖 • 1 关注
  • Jenkins

    Jenkins 是一套开源的持续集成工具。它提供了非常丰富的插件,让构建、部署、自动化集成项目变得简单易用。

    53 引用 • 37 回帖 • 3 关注
  • 区块链

    区块链是分布式数据存储、点对点传输、共识机制、加密算法等计算机技术的新型应用模式。所谓共识机制是区块链系统中实现不同节点之间建立信任、获取权益的数学算法 。

    91 引用 • 751 回帖 • 1 关注
  • 自由行
    4 关注
  • API

    应用程序编程接口(Application Programming Interface)是一些预先定义的函数,目的是提供应用程序与开发人员基于某软件或硬件得以访问一组例程的能力,而又无需访问源码,或理解内部工作机制的细节。

    77 引用 • 430 回帖 • 1 关注
  • 学习

    “梦想从学习开始,事业从实践起步” —— 习近平

    171 引用 • 512 回帖