嵌入快 SQL 自定义属性查询

我想在 daily note 中汇总每日的任务,目前是想利用任务列表插件生成的自定义属性 plugin-task-list-handleAt,用 sql 匹配年月日是当天的块,尝试了好久都未能成功,论坛也找不到方法,请大佬帮忙写下 sql 代码,谢谢。

image.png

  • 思源笔记

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

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

    23014 引用 • 92576 回帖
  • Q&A

    提问之前请先看《提问的智慧》,好的问题比好的答案更有价值。

    8447 引用 • 38484 回帖 • 155 关注
被采纳的回答
  • wilsons 2

    哦哦,这样应该可以吧

    SELECT * FROM blocks
    WHERE ial LIKE '%custom-plugin-task-list-handleAt="' || strftime('%Y%m%d', datetime('now')) || '%';
    

    如果不行,把你块自定义属性名截图看看,比如

    image.png

欢迎来到这里!

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

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

    大佬,我的块有自定义属性,属性值是 20241201211510 这样的日期格式,我想用 sql 匹配当天的的年月日,比如今天的就是匹配自定义属性值是 20241102 开头的块。明天会自动更新为匹配自定义属性值是 20241103 开头的块。

    1 回复
  • wilsons 2

    哦哦,这样应该可以吧

    SELECT * FROM blocks
    WHERE ial LIKE '%custom-plugin-task-list-handleAt="' || strftime('%Y%m%d', datetime('now')) || '%';
    

    如果不行,把你块自定义属性名截图看看,比如

    image.png

    3 回复
  • ONIONLYONE

    可以了大佬,非常感谢。截图帖子里有。

    1 回复
  • 哦哦,恭喜 ^ω^

  • 大佬,有没办法把这个自定义属性的时间格式在模板列显示出来,这样就能实现数据库获取到这个任务的时间了。就可以充分利用到任务列表那个插件的日历视图了,而不是在数据库里设置时间插件那里看不到日期要再设置一次

    2 回复
  • ONIONLYONE 1 评论

    佬,能细说一下想要达到的应用场景吗?想学习一下。

    数据库模版列代码 - 获取绑定的任务列表块的状态 0 看我这个贴,我主要用数据库管理任务,把子任务添加到数据库里,能把这个插件的时间属性带进数据库里就不用重复设置了
    5kyfkr
  • wilsons 1

    你试试这个可以吗

    .action{ if index . "custom-avs" }
    .action{ $id := .id }
    .action{ $blocks := queryBlocks "SELECT * FROM blocks WHERE id = '?'" $id }
    .action{ $b := first $blocks }
    .action{ $match := regexFind "custom-plugin-task-list-handleAt=\"([0-9]+)\"" $b.IAL }
    .action{ $value := trimPrefix "custom-plugin-task-list-handleAt=\"" $match }
    .action{ $value := trimSuffix "\"" $value }
    .action{ $value }
    .action{ end }
    

    仅保留年月日版

    .action{ if index . "custom-avs" }
    .action{ $id := .id }
    .action{ $blocks := queryBlocks "SELECT * FROM blocks WHERE id = '?'" $id }
    .action{ $b := first $blocks }
    .action{ $match := regexFind "custom-plugin-task-list-handleAt=\"([0-9]+)\"" $b.IAL }
    .action{ $value := trimPrefix "custom-plugin-task-list-handleAt=\"" $match }
    .action{ $value := trimSuffix "\"" $value }
    .action{ $year := substr 0 4 $value }
    .action{ $month := substr 4 6 $value }
    .action{ $day := substr 6 8 $value }
    .action{ $year }-.action{ $month }-.action{ $day }
    .action{ end }
    
    1 操作
    wilsons 在 2024-11-02 20:12:18 更新了该回帖
  • ONIONLYONE

    佬,我刚刚发现 daily note 文档中自定义属性,该值刚好是 20241102 这样的格式,能否把匹配当日日期变成匹配嵌入块所在的 daily note 文档自定义属性值呢,我现在的方案如果查看昨日 daily note 中的嵌入块,显示的也是今天的任务。另外,如果要加一天,也就是显示明天的任务,有办法实现吗,感谢。

    1 回复
  • wilsons 1

    用这个试试,粘贴到 SQL 查询文本框中即可

    //!js
    return (async () => {
        // sql查询语句
        const sql = `SELECT * FROM blocks WHERE ial LIKE '%custom-plugin-task-list-handleAt="${getCurrDocCustomAttr()}%';`;
    
        // 查询逻辑
        const result = await query(sql);
        if(result.length > 0) {
            return result.map(row=>row.id);
        }
        return [];
    
        // 获取当前文档的自定义属性值
        function getCurrDocCustomAttr() {
            const attributes = Array.from(item.parentElement.attributes);
            const attr = attributes.find(attr=>attr.name.startsWith('custom-dailynote'));
            return attr ? attr.value : '';
        }
    
        // 查询数据库
        async function query(sql) {
            const result = await fetchSyncPost('/api/query/sql', { "stmt": sql });
            if (result.code !== 0) {
                console.error("查询数据库出错", result.msg);
                return [];
            }
            return result.data;
        }
    })();
    
    1 回复
  • ONIONLYONE

    就是我想要的效果,原来这么复杂,我试了几小时放弃了 😂 。感谢大佬。

    另外我想再问下:

    1 如果要显示明天的,就是今天的加一天要怎么改。

    2 查询不到结果可以返回文本“今天没有任务了”,我记得之前自动添加到数据库的那个代码可以返回添加了多少文档,不知道这个可不可以。

    1 回复
  • wilsons 1

    查询明天的可以用这个 SQL

    SELECT * FROM blocks WHERE ial LIKE '%custom-plugin-task-list-handleAt="' || strftime('%Y%m%d', datetime('now', '+1 days')) || '%';
    

    自定义返回结果有点复杂,建议使用思源自带的"不存在符合条件的内容块"提示即可。

    如果有兴趣研究,可参考 建议增加“将文内所有 x 级标题转化为 x 级标题” - wilsons 的回帖

    1 回复
  • ONIONLYONE

    好的好的,太感谢大佬了 ORZ

  • YRJ0422

    听起来你可以使用集市里面的极简 TODO 模版

    1 回复
  • ONIONLYONE

    感谢推荐,我也有看过那个模板的介绍,但是那个模板是每日的日程是写在 daily note 里面的吧?我的日程是写在其他笔记里,在 daily note 里面汇总,有关还是不一样。

    1 回复
  • YRJ0422

    一样可以汇总,需要配合快速添加属性插件,不过我技术有限,除了模版生成的,其他地方手动添加的块属性都保持一致一个时间值,也可以手动加属性不用插件就是麻烦点

    1 回复
  • ONIONLYONE

    刚刚试了下。改了下极简 todo 的模板也实现了功能,我是配合任务列表这个插件使用的。

    1 回复
    2 操作
    ONIONLYONE 在 2024-11-05 17:38:54 更新了该回帖
    ONIONLYONE 在 2024-11-05 16:15:12 更新了该回帖
  • YRJ0422 1

    参考我这个使用方法,也挺方便的

  • lssw1001

    感谢一下大佬,我就是通过您这两个链接提供的代码实现了自动索引当日未完成任务,以及改了一下日期格式。

    QAQ 我之前还每天手动复制,我以前真是笨的可以 🙏

请输入回帖内容 ...

推荐标签 标签

  • Q&A

    提问之前请先看《提问的智慧》,好的问题比好的答案更有价值。

    8447 引用 • 38484 回帖 • 155 关注
  • LaTeX

    LaTeX(音译“拉泰赫”)是一种基于 ΤΕΧ 的排版系统,由美国计算机学家莱斯利·兰伯特(Leslie Lamport)在 20 世纪 80 年代初期开发,利用这种格式,即使使用者没有排版和程序设计的知识也可以充分发挥由 TeX 所提供的强大功能,能在几天,甚至几小时内生成很多具有书籍质量的印刷品。对于生成复杂表格和数学公式,这一点表现得尤为突出。因此它非常适用于生成高印刷质量的科技和数学类文档。

    12 引用 • 54 回帖 • 49 关注
  • TGIF

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

    288 引用 • 4485 回帖 • 663 关注
  • 又拍云

    又拍云是国内领先的 CDN 服务提供商,国家工信部认证通过的“可信云”,乌云众测平台认证的“安全云”,为移动时代的创业者提供新一代的 CDN 加速服务。

    21 引用 • 37 回帖 • 548 关注
  • CloudFoundry

    Cloud Foundry 是 VMware 推出的业界第一个开源 PaaS 云平台,它支持多种框架、语言、运行时环境、云平台及应用服务,使开发人员能够在几秒钟内进行应用程序的部署和扩展,无需担心任何基础架构的问题。

    5 引用 • 18 回帖 • 172 关注
  • JRebel

    JRebel 是一款 Java 虚拟机插件,它使得 Java 程序员能在不进行重部署的情况下,即时看到代码的改变对一个应用程序带来的影响。

    26 引用 • 78 回帖 • 672 关注
  • CongSec

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

    1 引用 • 1 回帖 • 15 关注
  • 学习

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

    171 引用 • 512 回帖
  • TensorFlow

    TensorFlow 是一个采用数据流图(data flow graphs),用于数值计算的开源软件库。节点(Nodes)在图中表示数学操作,图中的线(edges)则表示在节点间相互联系的多维数据数组,即张量(tensor)。

    20 引用 • 19 回帖 • 1 关注
  • Logseq

    Logseq 是一个隐私优先、开源的知识库工具。

    Logseq is a joyful, open-source outliner that works on top of local plain-text Markdown and Org-mode files. Use it to write, organize and share your thoughts, keep your to-do list, and build your own digital garden.

    6 引用 • 63 回帖 • 5 关注
  • 分享

    有什么新发现就分享给大家吧!

    248 引用 • 1795 回帖 • 1 关注
  • 运维

    互联网运维工作,以服务为中心,以稳定、安全、高效为三个基本点,确保公司的互联网业务能够 7×24 小时为用户提供高质量的服务。

    149 引用 • 257 回帖
  • WiFiDog

    WiFiDog 是一套开源的无线热点认证管理工具,主要功能包括:位置相关的内容递送;用户认证和授权;集中式网络监控。

    1 引用 • 7 回帖 • 592 关注
  • WebSocket

    WebSocket 是 HTML5 中定义的一种新协议,它实现了浏览器与服务器之间的全双工通信(full-duplex)。

    48 引用 • 206 回帖 • 318 关注
  • 工具

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

    288 引用 • 734 回帖 • 2 关注
  • 程序员

    程序员是从事程序开发、程序维护的专业人员。

    574 引用 • 3533 回帖
  • Linux

    Linux 是一套免费使用和自由传播的类 Unix 操作系统,是一个基于 POSIX 和 Unix 的多用户、多任务、支持多线程和多 CPU 的操作系统。它能运行主要的 Unix 工具软件、应用程序和网络协议,并支持 32 位和 64 位硬件。Linux 继承了 Unix 以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统。

    946 引用 • 943 回帖
  • SpaceVim

    SpaceVim 是一个社区驱动的模块化 vim/neovim 配置集合,以模块的方式组织管理插件以
    及相关配置,为不同的语言开发量身定制了相关的开发模块,该模块提供代码自动补全,
    语法检查、格式化、调试、REPL 等特性。用户仅需载入相关语言的模块即可得到一个开箱
    即用的 Vim-IDE。

    3 引用 • 31 回帖 • 104 关注
  • 数据库

    据说 99% 的性能瓶颈都在数据库。

    343 引用 • 723 回帖
  • Postman

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

    4 引用 • 3 回帖 • 7 关注
  • 链滴

    链滴是一个记录生活的地方。

    记录生活,连接点滴

    156 引用 • 3792 回帖
  • Webswing

    Webswing 是一个能将任何 Swing 应用通过纯 HTML5 运行在浏览器中的 Web 服务器,详细介绍请看 将 Java Swing 应用变成 Web 应用

    1 引用 • 15 回帖 • 637 关注
  • HHKB

    HHKB 是富士通的 Happy Hacking 系列电容键盘。电容键盘即无接点静电电容式键盘(Capacitive Keyboard)。

    5 引用 • 74 回帖 • 478 关注
  • jQuery

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

    63 引用 • 134 回帖 • 724 关注
  • 快应用

    快应用 是基于手机硬件平台的新型应用形态;标准是由主流手机厂商组成的快应用联盟联合制定;快应用标准的诞生将在研发接口、能力接入、开发者服务等层面建设标准平台;以平台化的生态模式对个人开发者和企业开发者全品类开放。

    15 引用 • 127 回帖
  • Solidity

    Solidity 是一种智能合约高级语言,运行在 [以太坊] 虚拟机(EVM)之上。它的语法接近于 JavaScript,是一种面向对象的语言。

    3 引用 • 18 回帖 • 401 关注
  • 域名

    域名(Domain Name),简称域名、网域,是由一串用点分隔的名字组成的 Internet 上某一台计算机或计算机组的名称,用于在数据传输时标识计算机的电子方位(有时也指地理位置)。

    43 引用 • 208 回帖