思源笔记内嵌 sql 查询文档求助

想通过内嵌 sql 查询包含指定标签的文档,需要返回的列有:

文档标题,链接,封面图,创建时间等字段。 其中获取文档封面图显示在表格中不会,求教!

  • 思源笔记

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

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

    25222 引用 • 104018 回帖 • 1 关注
  • Q&A

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

    9642 引用 • 43840 回帖 • 95 关注

相关帖子

被采纳的回答

欢迎来到这里!

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

注册 关于
请输入回帖内容 ...
  • 太复杂了,要 js 才能实现,而且估计要出点零钱找个大佬远程帮你写(我不是),光靠文字来回沟通太低效。

  • wilsons 1 1 评论

    这是以前写的代码,增加了显示封面功能,不知是否满足你的需求。

    由于链接已经在标题中了,就没有再次显示。

    效果:

    image.png

    代码:

    https://gitee.com/wish163/mysoft/blob/main/%E6%80%9D%E6%BA%90/SQL%E8%87%AA%E5%AE%9A%E4%B9%89%E6%9F%A5%E8%AF%A2%E7%BB%93%E6%9E%9C.js

    使用说明:

    第一步:编辑器中输入 {{}} ,然后把上述代码输入到输入框即可

    第二步:

    只需要修改这个 👇 标签名参数即可,更多功能请参考源码
    const tag = 'demo1';

    2 回复
    您好,我有 2 个问题。如果我想只显示文档块,不想显示内容块里包含标签的,应该怎么改?第二个问题,我想查询所有图片链接是 http 开头的块(即网络图片),要改动哪里?
    MasterYS
  • lichlaughing via macOS

    我的天,原来这么复杂 😳 。厉害了,我想要这样的结果,我研究下。

  • @MasterYS

    只显示文档块,不想显示内容块里包含标签的

    这个只需要修改 SQL 即可

    // sql查询语句 const sql = ` SELECT * FROM blocks where type = 'd' -- 排除文档头部有标签的 -- and tag = '' -- 排除文档块中有标签的 and id not in ( SELECT root_id FROM blocks where type <> 'd' and tag <> '' ) ORDER BY created desc; `;

    第二个问题,我想查询所有图片链接是 http 开头的块(即网络图片)

    这个,由于你要显示的是块,稍微麻烦点,需要把 SQL 和 render 调用都改下

    // sql查询语句 const sql = `SELECT * FROM blocks WHERE type not in ('c', 'query_embed') and markdown like '%![%](http%)%' ORDER BY created desc;`; // 查询数据 const result = await query(sql); // 渲染结果,这里第二个参数是指定显示的字段,按你指定的顺序显示 render(result, ['块内容', '创建时间'], ({row, index, options, toRef, formatDate, renderMarkdown})=>{ // 渲染前回调,这里可以进行一些数据格式化 row['块内容'] = toRef(renderMarkdown(row['markdown']), row['id']); row['创建时间'] = formatDate(row['created']); });

    效果

    image.png

    1 回复
  • MasterYS

    老师,我测试了一早上,第二个问题解决了,有个小问题,我的初衷是想找出忘记将图片本地化的文档,但是现在这个会显示文字超链,如果要改成只找出图片是不是有点复杂。当然这个已经够用了,可以不处理。

    第一个问题就比较多,我用你最早提供的代码显示标签,有个小 bug 就是,显示文档块没问题,但是显示文本块带标签的时候,会加载出文本块后,其他块,而初衷应该是只显示第一个块,如下图

    图片.png

    所以我才提了需要,说看能否屏蔽掉文本块,只显示文档,但是这样确实有缺失。如果能改成只显示带标签的第一个块就好了。

    另外,我用你的屏蔽掉文本块的代码的时候,确实屏蔽掉文本快带标签的,但是有个 bug,就是他会把好多不想关的文档加载出来,就是标签不含指定标签的,都显示出来

    1 回复
    1. 不清楚你的问题,已经限制了 type='d'了,是不可能查出块文本的,不清楚你那边具体怎么回事

      会把好多不想关的文档加载出来,就是标签不含指定标签的

      不含指定标签,这个是因为你之前的帖子中没有指出要查指定标签,没加指定标签条件,把原文中的指定标签条件加上就好了。

    2. row['块内容'] = toRef(renderMarkdown(row['markdown']), row['id']); 改成 row['块内容'] = row['markdown'].match(/!\[.*?\]\(https?:\/\/[^\)]*\)/ig)?.join(' ')||'';
      这样,只会提取 Markdown 中的图片源码,以文本显示。如果要渲染图片再加上 renderMarkdown 即可。

    1 回复
  • MasterYS

    老师,可能我没说清楚,我截图显示的是你第一次提供的代码。也就是没有限制不显示文本块的时候。我现在如果想显示文本块。但是只显示第一个块,也就是只显示带标签的块。标签后面的块不显示,应该怎么改。

    另外您给我的屏蔽掉,文本块的代码,使用后有 bug,确实不显示文本块了,但是显示了其他标签的文档

  • MasterYS

    就是这个您库里的代码,用了之后,带标签的文本块会加载出多余的内容。

    图片.png

请输入回帖内容 ...

推荐标签 标签

  • API

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

    79 引用 • 431 回帖
  • Shell

    Shell 脚本与 Windows/Dos 下的批处理相似,也就是用各类命令预先放入到一个文件中,方便一次性执行的一个程序文件,主要是方便管理员进行设置或者管理用的。但是它比 Windows 下的批处理更强大,比用其他编程程序编辑的程序效率更高,因为它使用了 Linux/Unix 下的命令。

    124 引用 • 74 回帖
  • 黑曜石

    黑曜石是一款强大的知识库工具,支持本地 Markdown 文件编辑,支持双向链接和关系图。

    A second brain, for you, forever.

    22 引用 • 214 回帖
  • TensorFlow

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

    20 引用 • 19 回帖 • 3 关注
  • RESTful

    一种软件架构设计风格而不是标准,提供了一组设计原则和约束条件,主要用于客户端和服务器交互类的软件。基于这个风格设计的软件可以更简洁,更有层次,更易于实现缓存等机制。

    30 引用 • 114 回帖 • 6 关注
  • 小薇

    小薇是一个用 Java 写的 QQ 聊天机器人 Web 服务,可以用于社群互动。

    由于 Smart QQ 从 2019 年 1 月 1 日起停止服务,所以该项目也已经停止维护了!

    35 引用 • 468 回帖 • 760 关注
  • Eclipse

    Eclipse 是一个开放源代码的、基于 Java 的可扩展开发平台。就其本身而言,它只是一个框架和一组服务,用于通过插件组件构建开发环境。

    76 引用 • 258 回帖 • 626 关注
  • 京东

    京东是中国最大的自营式电商企业,2015 年第一季度在中国自营式 B2C 电商市场的占有率为 56.3%。2014 年 5 月,京东在美国纳斯达克证券交易所正式挂牌上市(股票代码:JD),是中国第一个成功赴美上市的大型综合型电商平台,与腾讯、百度等中国互联网巨头共同跻身全球前十大互联网公司排行榜。

    14 引用 • 102 回帖 • 318 关注
  • OkHttp

    OkHttp 是一款 HTTP & HTTP/2 客户端库,专为 Android 和 Java 应用打造。

    16 引用 • 6 回帖 • 85 关注
  • 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.

    7 引用 • 69 回帖
  • 友情链接

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

    24 引用 • 373 回帖
  • HHKB

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

    5 引用 • 74 回帖 • 503 关注
  • 一些有用的避坑指南。

    69 引用 • 93 回帖
  • 宕机

    宕机,多指一些网站、游戏、网络应用等服务器一种区别于正常运行的状态,也叫“Down 机”、“当机”或“死机”。宕机状态不仅仅是指服务器“挂掉了”、“死机了”状态,也包括服务器假死、停用、关闭等一些原因而导致出现的不能够正常运行的状态。

    13 引用 • 82 回帖 • 75 关注
  • SQLite

    SQLite 是一个进程内的库,实现了自给自足的、无服务器的、零配置的、事务性的 SQL 数据库引擎。SQLite 是全世界使用最为广泛的数据库引擎。

    5 引用 • 7 回帖
  • 996
    13 引用 • 200 回帖 • 2 关注
  • IDEA

    IDEA 全称 IntelliJ IDEA,是一款 Java 语言开发的集成环境,在业界被公认为最好的 Java 开发工具之一。IDEA 是 JetBrains 公司的产品,这家公司总部位于捷克共和国的首都布拉格,开发人员以严谨著称的东欧程序员为主。

    181 引用 • 400 回帖
  • Notion

    Notion - The all-in-one workspace for your notes, tasks, wikis, and databases.

    10 引用 • 77 回帖 • 2 关注
  • Sym

    Sym 是一款用 Java 实现的现代化社区(论坛/BBS/社交网络/博客)系统平台。

    下一代的社区系统,为未来而构建

    524 引用 • 4601 回帖 • 704 关注
  • 知乎

    知乎是网络问答社区,连接各行各业的用户。用户分享着彼此的知识、经验和见解,为中文互联网源源不断地提供多种多样的信息。

    10 引用 • 66 回帖 • 1 关注
  • MyBatis

    MyBatis 本是 Apache 软件基金会 的一个开源项目 iBatis,2010 年这个项目由 Apache 软件基金会迁移到了 google code,并且改名为 MyBatis ,2013 年 11 月再次迁移到了 GitHub。

    173 引用 • 414 回帖 • 368 关注
  • 浅吟主题

    Jeffrey Chen 制作的思源笔记主题,项目仓库:https://github.com/TCOTC/Whisper

    1 引用 • 28 回帖 • 1 关注
  • Kotlin

    Kotlin 是一种在 Java 虚拟机上运行的静态类型编程语言,由 JetBrains 设计开发并开源。Kotlin 可以编译成 Java 字节码,也可以编译成 JavaScript,方便在没有 JVM 的设备上运行。在 Google I/O 2017 中,Google 宣布 Kotlin 成为 Android 官方开发语言。

    19 引用 • 33 回帖 • 81 关注
  • 外包

    有空闲时间是接外包好呢还是学习好呢?

    26 引用 • 233 回帖 • 3 关注
  • CodeMirror
    2 引用 • 17 回帖 • 161 关注
  • 互联网

    互联网(Internet),又称网际网络,或音译因特网、英特网。互联网始于 1969 年美国的阿帕网,是网络与网络之间所串连成的庞大网络,这些网络以一组通用的协议相连,形成逻辑上的单一巨大国际网络。

    99 引用 • 367 回帖
  • Webswing

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

    1 引用 • 15 回帖 • 642 关注