尝试通过查询语句来动态构建数据库

本贴最后更新于 271 天前,其中的信息可能已经事过景迁

上次尝试了一下实现一个 SuperRef 之后 ld246.com/article/1739206311467 很快意识到了一个问题,所谓 SuperRef 的核心算子是就两个:

  1. 反链查询(包括重定向操作)
  2. 根据搜索的内容更新数据库的行

反链查询的目的只是为了得到要加入数据库的块,所以可以不局限于反链,而是通过各种查询动态地构建数据库。

不过反链查询毕竟有特殊的含义,所以为了和 SuperRef 区别,把这个功能称为 Dynamic Database。他和 SuperRef 的本质其实是一样,小区别在于:SuperRef 是把数据库绑定一个文档,而 Dynamic Database 则只针对数据库本身。

现在使用 fmisc 5.6.0 版本之后,点击数据库旁边的按钮可以把它设置为一个「动态数据库」。

图片.png

在里面放一些查询语句,这里的案例是收集所有有 TODO 和 DOING tag 的条目。

图片.png

点击一下「更新数据库」按钮,就自动创建条目了。

由于我查询的是标签,所以在数据库中增加一个模板列,把块中的标签信息提取出来。

.action{ $blocks := queryBlocks "select * from blocks where id='?'" .id}
.action{ if not (empty $blocks) }
.action{ $tag := (first $blocks).Tag | replace "#" "" }
<span data-type="tag">.action{ $tag }</span>
.action{ end }

大致效果是这样的:

图片.png

可以用以下的 SQL 查询所有绑定了动态构建规则的数据库(汇总在书签侧边栏中)

select * from blocks where type='av' and ial like '%custom-dynamic-database%' order by updated desc;

不过说实话,我自己尝试几天后,发现这个功能的定位有点尴尬。

原因在于到目前为止,如何聚合内容块,我自己已经有了三种方案:

  • 基于 QueryView,优点是非常灵活
  • 基于书签 +,优点是可以不用打开文档而在软件最顶层显示
  • 基于(SuperRef)数据库,优点是可以添加自定义的列以补充元信息

图片.png

使用数据库的核心优势就是可以补充列,那对我来说问题就来了:

  • 如果添加元信息很重要,那完全可以用 SuperRef 绑定到一个主题文档
  • 如果添加元信息不重要,那完全可以用更灵活的 QueryView ,或者聚合到侧边书签当中

所以这种动态构建数据库的方案上不去下不来,感觉有点鸡肋。到底实际价值有多大,就交给其他人来自行评判了。

  • 思源笔记

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

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

    28446 引用 • 119786 回帖
  • QueryView
    21 引用 • 84 回帖

相关帖子

欢迎来到这里!

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

注册 关于
请输入回帖内容 ...
  • veryzhh 3 评论

    感谢 F 佬,又提供了一个强大的功能!我用了新的动态数据库,有两点体会。

    两点体会:

    • 标签式动态数据库很有用,更有利于对标签对象进行管理。
      • 虽然书签 + 里调取会更直接,但后续管理的衔接不是太方便,用数据库就可以设置不同的筛选视图,并给标签对象的情况加状态或说明。
      • 对于普通的标签,可以不需要这一步;但对于有后续管理动作的标签,动态数据库就很有用了。
    • 关键词动态数据库,使一些特定的日常札记的收录,更加便捷。
      • 比如,我偶尔会在日记中记录自己做的梦,以前需要右键送到相应数据库(当然也可以用 SuperRef 方式),但这都要多一个动作。现在只要描述中有“做了个梦”,这一段落块就自动添加到记录梦的数据库了。对于日常札记这种很普通的事来说,完全不需要有多余的动作,只要记录的内容中有特定的表述就行了。
      • 这一方式不足是,关键词不能过于通用(简单),否则如果别的文章里刚好大量使用了该词,那就是“灾难”了。

    一点疑问:

    • 我抄了 F 佬你在图片中提供的 JS 代码,来收集指定标签对象信息,但不知为什么跑不通。使用以下代码后,会提示 blocks.sorton is not a function,把 blocks = blocks.sorton('updated');//,去掉下一行的 //,又会提示 查询没有返回结果
    //!js
    let blocks = await Query.sql(`
    select * from blocks where (type='p' or type='d' or type='h')
    and (tag like '#待梳理#' or tag like '#待完善#')
    `);
    blocks = blocks.sorton('updated');
    //blocks = await Query.fb2p(blocks);
    return blocks.pick('id');
    
    • 后来用书签 + 试过其中的 SQL 代码是可用的,我就套用了您在设置面板上提供的 JS 代码,这次可以调取查询数据到数据库了。我上面所模仿的 JS 代码中到底有什么问题呢?还是这个代码需要什么插件或功能来支持?还望 F 佬不吝赐教 🙏 。
    //!js
    const blocks = await sql("SELECT * FROM blocks WHERE (type='p' OR type='d' OR type='h')  AND (tag LIKE '%#待梳理#%' OR tag LIKE '%#待完善#%')");
    return blocks.map(b => b.id);
    
    1 操作
    veryzhh 在 2025-05-09 14:20:15 更新了该回帖
    没有什么问题, blocks.sorton 和 fb2p 都不是必须的;另外没有 sorton 可能是 QV 的版本不太对,我印象中这几个版本我更改过这部分的代码。不过 sorton 不影响最后的结果,删掉也无所谓。
    Frostime
    哦,我注意到了,你用的是 sql 而不是 Query.sql 是吧?那确实不会有 sorton。 sorton 和 pick 都是 QueryView 里面对列表封装了一层后增加的方法,普通列表里面是没有这些方法的。
    Frostime
    @Frostime 我装了 Query & View,但还不会用,所以只是装了插件本身,没做任何配置。看来应该是这个原因了。
    veryzhh
  • onemo

    要是能自动更新动态数据库就更好了 😋

  • GloR

    感谢分享!要是主键里的“#TODO#”能自动删掉就好了,这样可以更清爽 + 一目了然

  • onemo

    v6.1.0 支持 {{CurDocId}} 变量渲染啦,通过动态数据库可以用数据库的各种视图展示子文档或子孙文档。

    子文档:

    select * from blocks
    where path like '%/{{CurDocId}}/______________-_______.sy' and type='d'
    LIMIT 1000;
    

    子孙文档:

    select * from blocks
    where path like '%/{{CurDocId}}/%' and type='d'
    LIMIT 1000;
    
  • zhangu

    mark 下

  • seabirdr

    首先要赞一句,动态数据库的理念和设计真的太棒了,正中我的需求红心!但是在满怀期待地试用时,我遇到了一个问题,录了个屏给你反馈。

    情况是这样的:

    初始化顺利:数据搜索、首次添加到数据库,一切正常。

    更新时出现问题:每次刷新(无论是自动还是手动),都会跳出提示:「部分内容块原本在数据库中,但已经不在新的查询结果中,是否需要从数据库中删除他们?」

    结果:如视频所示,明明没有任何改动,插件却会误删已存在的条目,然后又重新把它们加回来。在视频的后半段,我手动多次刷新动态数据库,数据库的条目数量在 2 和 3 之间反复横跳

    麻烦你有空时帮忙看看,如果需要,我可以协助测试,感谢你的创造!

  • 动态数据库我遇到有些数据库想要保留孤立数据,有些动态数据库要删除孤立数据,有些数据库想询问,这个可能有个变量或属性可以控制某个具体动态数据库的行为吗?

请输入回帖内容 ...

推荐标签 标签

  • CSS

    CSS(Cascading Style Sheet)“层叠样式表”是用于控制网页样式并允许将样式信息与网页内容分离的一种标记性语言。

    200 引用 • 545 回帖 • 1 关注
  • Maven

    Maven 是基于项目对象模型(POM)、通过一小段描述信息来管理项目的构建、报告和文档的软件项目管理工具。

    188 引用 • 319 回帖 • 222 关注
  • Windows

    Microsoft Windows 是美国微软公司研发的一套操作系统,它问世于 1985 年,起初仅仅是 Microsoft-DOS 模拟环境,后续的系统版本由于微软不断的更新升级,不但易用,也慢慢的成为家家户户人们最喜爱的操作系统。

    232 引用 • 484 回帖
  • 职场

    找到自己的位置,萌新烦恼少。

    127 引用 • 1708 回帖 • 1 关注
  • OnlyOffice
    4 引用 • 41 关注
  • frp

    frp 是一个可用于内网穿透的高性能的反向代理应用,支持 TCP、UDP、 HTTP 和 HTTPS 协议。

    17 引用 • 7 回帖 • 1 关注
  • 叶归
    25 引用 • 100 回帖 • 37 关注
  • Netty

    Netty 是一个基于 NIO 的客户端-服务器编程框架,使用 Netty 可以让你快速、简单地开发出一个可维护、高性能的网络应用,例如实现了某种协议的客户、服务端应用。

    49 引用 • 33 回帖 • 63 关注
  • ngrok

    ngrok 是一个反向代理,通过在公共的端点和本地运行的 Web 服务器之间建立一个安全的通道。

    7 引用 • 63 回帖 • 668 关注
  • 星云链

    星云链是一个开源公链,业内简单的将其称为区块链上的谷歌。其实它不仅仅是区块链搜索引擎,一个公链的所有功能,它基本都有,比如你可以用它来开发部署你的去中心化的 APP,你可以在上面编写智能合约,发送交易等等。3 分钟快速接入星云链 (NAS) 测试网

    3 引用 • 16 回帖
  • Spring

    Spring 是一个开源框架,是于 2003 年兴起的一个轻量级的 Java 开发框架,由 Rod Johnson 在其著作《Expert One-On-One J2EE Development and Design》中阐述的部分理念和原型衍生而来。它是为了解决企业应用开发的复杂性而创建的。框架的主要优势之一就是其分层架构,分层架构允许使用者选择使用哪一个组件,同时为 JavaEE 应用程序开发提供集成的框架。

    950 引用 • 1460 回帖 • 2 关注
  • TGIF

    Thank God It's Friday! 感谢老天,总算到星期五啦!

    293 引用 • 4496 回帖 • 688 关注
  • Mobi.css

    Mobi.css is a lightweight, flexible CSS framework that focus on mobile.

    1 引用 • 6 回帖 • 799 关注
  • Hibernate

    Hibernate 是一个开放源代码的对象关系映射框架,它对 JDBC 进行了非常轻量级的对象封装,使得 Java 程序员可以随心所欲的使用对象编程思维来操纵数据库。

    39 引用 • 103 回帖 • 740 关注
  • JavaScript

    JavaScript 一种动态类型、弱类型、基于原型的直译式脚本语言,内置支持类型。它的解释器被称为 JavaScript 引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在 HTML 网页上使用,用来给 HTML 网页增加动态功能。

    736 引用 • 1307 回帖 • 2 关注
  • 人工智能

    人工智能(Artificial Intelligence)是研究、开发用于模拟、延伸和扩展人的智能的理论、方法、技术及应用系统的一门技术科学。

    140 引用 • 407 回帖
  • WordPress

    WordPress 是一个使用 PHP 语言开发的博客平台,用户可以在支持 PHP 和 MySQL 数据库的服务器上架设自己的博客。也可以把 WordPress 当作一个内容管理系统(CMS)来使用。WordPress 是一个免费的开源项目,在 GNU 通用公共许可证(GPLv2)下授权发布。

    46 引用 • 114 回帖 • 139 关注
  • V2EX

    V2EX 是创意工作者们的社区。这里目前汇聚了超过 400,000 名主要来自互联网行业、游戏行业和媒体行业的创意工作者。V2EX 希望能够成为创意工作者们的生活和事业的一部分。

    16 引用 • 236 回帖 • 224 关注
  • jQuery

    jQuery 是一套跨浏览器的 JavaScript 库,强化 HTML 与 JavaScript 之间的操作。由 John Resig 在 2006 年 1 月的 BarCamp NYC 上释出第一个版本。全球约有 28% 的网站使用 jQuery,是非常受欢迎的 JavaScript 库。

    63 引用 • 134 回帖 • 736 关注
  • SSL

    SSL(Secure Sockets Layer 安全套接层),及其继任者传输层安全(Transport Layer Security,TLS)是为网络通信提供安全及数据完整性的一种安全协议。TLS 与 SSL 在传输层对网络连接进行加密。

    70 引用 • 193 回帖 • 404 关注
  • 支付宝

    支付宝是全球领先的独立第三方支付平台,致力于为广大用户提供安全快速的电子支付/网上支付/安全支付/手机支付体验,及转账收款/水电煤缴费/信用卡还款/AA 收款等生活服务应用。

    29 引用 • 347 回帖 • 2 关注
  • Openfire

    Openfire 是开源的、基于可拓展通讯和表示协议 (XMPP)、采用 Java 编程语言开发的实时协作服务器。Openfire 的效率很高,单台服务器可支持上万并发用户。

    6 引用 • 7 回帖 • 133 关注
  • Wide

    Wide 是一款基于 Web 的 Go 语言 IDE。通过浏览器就可以进行 Go 开发,并有代码自动完成、查看表达式、编译反馈、Lint、实时结果输出等功能。

    欢迎访问我们运维的实例: https://wide.b3log.org

    30 引用 • 218 回帖 • 664 关注
  • 游戏

    沉迷游戏伤身,强撸灰飞烟灭。

    188 引用 • 833 回帖 • 1 关注
  • Node.js

    Node.js 是一个基于 Chrome JavaScript 运行时建立的平台, 用于方便地搭建响应速度快、易于扩展的网络应用。Node.js 使用事件驱动, 非阻塞 I/O 模型而得以轻量和高效。

    139 引用 • 269 回帖 • 1 关注
  • OpenResty

    OpenResty 是一个基于 NGINX 与 Lua 的高性能 Web 平台,其内部集成了大量精良的 Lua 库、第三方模块以及大多数的依赖项。用于方便地搭建能够处理超高并发、扩展性极高的动态 Web 应用、Web 服务和动态网关。

    17 引用 • 51 关注
  • BAE

    百度应用引擎(Baidu App Engine)提供了 PHP、Java、Python 的执行环境,以及云存储、消息服务、云数据库等全面的云服务。它可以让开发者实现自动地部署和管理应用,并且提供动态扩容和负载均衡的运行环境,让开发者不用考虑高成本的运维工作,只需专注于业务逻辑,大大降低了开发者学习和迁移的成本。

    19 引用 • 75 回帖 • 702 关注