导入的.sy 文档后,移动文档(为了排序),出现文件已经存在的问题

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

image.png

问题描述

如上图。我从别处导出一个名为 fp.sy 的压缩包文件,然后把它导入到另一个 siyuan 客户端,导入步骤是:我先在 siyuan 客户端中新建笔记本,命名为 fp;然后导入 fp.sy 的压缩包到该笔记本

出现如下问题:

在新的 siyuan 客户端中,调整 fp 笔记本下的文档排列顺序,然后出现上述图中的文件已存在问题;

但是,在该 fp 笔记本中新建文档,然后移动新建文档,不存在“文件已存在的问题”。

  • 思源笔记

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

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

    20644 引用 • 80672 回帖 • 1 关注
4 操作
fengjiannju 在 2022-11-16 14:59:21 更新了该帖
fengjiannju 在 2022-11-16 14:56:14 更新了该帖
fengjiannju 在 2022-11-16 14:54:16 更新了该帖
fengjiannju 在 2022-11-16 14:52:37 更新了该帖

相关帖子

欢迎来到这里!

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

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

    再次补充说明

    经过我再次测试,发现:

    docker 端通过网页,问题根源是:如果被移动的文档下面还有子文档,则会提示、警告“文件已存在”问题,该提示、警告不影响文档移动、排序。如果被移动重排序的文档下方没有子文档,则不会提示、警告“文件已存在”

    上述问题,win10 桌面客户端不存在。

    image.png

    1 回复
  • 其他回帖
  • fengjiannju

    刚才我又试了一次,还是有 bug

    我认为,背后原因可能是,我导出的内容,有跨笔记本引用。

    我导出的 siyuan1 客户端中的 fp 笔记本,但是 fp 中某些笔记引用了 siyuan1 中的其他笔记本中的内容。这样把到处的 fp 导入到 siyuan2 客户端:可能导致上述问题,

    另外我还发现,导入到 siyuan2 中的 fp 笔记本内的某些文档丢失名字,成为 Untitle。

    担心将来索引效率问题

    我想导出,是因为担心数据量越来越大后,影响索引效率。

    请教下,如果未来数据量太大,我还想保持高速索引,可以通过使用更强大的 cpu(多核心、更高主频)和更大内存来并行查找索引中内容来提高效率吗?
    我粗略了解一些数据库索引原理,关键就是在内存中查找数据。那理论上性能更强劲 cpu 配合更大内存,可以解决索引问题?
    如果我的想法正确,那我就不使用导出功能了,将来数据量太大影响检索效率,上更强劲的 cpu、更大频率更高的内存即可解决,就不用把数据分拆到好几个 siyuan 客户端了。

    我现在用着索引太爽了,就怕将来不爽了痛苦。所以现在就得想好到底是把数据分开来,还是将来上更强劲的硬件。

    1 回复
  • 刚刚我测试了跨笔记本引用再导出,也没有能重现问题,跨笔记本会把引用的文档一并导出的。

    至于性能问题,任何软件都有一定的上限,但是作为前期使用不必太有顾虑,可以按照一个月或者三个月这样的周期测算一下数据增长情况,然后预估按照这个增长能够支持多久,如果是几年的话我觉得近期就没有必要太在乎性能影响了,几年以后升级一下硬件可能就解决问题了。

    如果实在有顾虑,建议通过拆分笔记本或者工作空间来使用,但是我个人觉得这样用的话比较累,而且过度的分类规则也是种自我设限,没有太大必要。

    对于数据库的性能,在个人电脑上差不多就是几十万到百万条记录差不多能够在可以接受的性能范围内,再多的话我觉得也没有多少工具能够支持全文搜索了,不信的话你可以找一些笔记软件测试一下性能,当文档数量上万以后看看全文搜索的性能差异,我相信思源还是很难能打的。

    1 回复
  • fengjiannju 1

    补充说明:我认为是 linux、docker 版文件处理机制问题,理由如下

    现在的情况是:siyuan2 客户端部署在 linux mint 上的 docker,而移动文件排序产生“文件已存在”的问题。【这个问题产生的原因:就是我有两个 siyuan1、siyuan2 运行在 docker,且他们的工作空间是独立的。我在网页端把 siyuan1 的文件导出,再到网页端导入到 siyuan2】

    如下图所示,我在 siyuan2 客户端把 2022-11-11 文档移动到 2022-11-14 上方,立马报错,来回移动两个文件顺讯,一直报错,但是文件顺序的确能移动了。只是不爽!

    image.png

    随后做了如下测试:

    将 siyuan2 的数据同步到云端后,关闭容器:sudo docker stop siyuan2。
    再在 win10 上安装全新的 siyuan 2.5.0 客户端,,从云端同步数据库,同步完毕后,win10 客户端移动同样的文件:将 2022-11-11 和 2022-11-14 来回移动顺序,不会出错——不会出现“文件已存在”的问题。如下图
    同步,退出 win10 siyuan。

    image.png

    在 linux 上,再 run 一个新的 siyuan3 客户端(开辟全新、独立的工作空间),导入秘钥、并把云端数据同步下来,再来回移动同样的文件的顺序(2022-11-11 和 2022-11-15),又出现文件已存在的问题。

    综上,我认为原因可能是:

    1. docker 客户端下,与移动文件进行排序相关的文件处理过程有错,与 win10 下的处理过程不同,即 win10 的正确,docker 或者 linux 的有错
    2. 或者与移动文件进行排序相关的文件处理过程没错(win10 docker linux 都正确),但是 docker、linux 客户端会误发出“文件已存在”的警告,而 win10 版本不会发出警告——即,当对文件进行移动排序时,如果文件实际存放位置没有发生变化,则此时 linux、docker 客户端的底层的文件操作函数返回“文件已存在,移动失败”(但不影响 siyuan 文档树内的文档排序调整结果),而 win10 系统下的底层文件操作函数不会发出警告。

    @88250

    1 回复
    2 操作
    fengjiannju 在 2022-11-17 10:22:32 更新了该回帖
    fengjiannju 在 2022-11-17 10:21:44 更新了该回帖
  • 查看全部回帖

推荐标签 标签

  • Notion

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

    5 引用 • 26 回帖
  • WiFiDog

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

    1 引用 • 7 回帖 • 576 关注
  • 友情链接

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

    24 引用 • 373 回帖 • 1 关注
  • 知乎

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

    10 引用 • 66 回帖
  • ngrok

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

    7 引用 • 63 回帖 • 623 关注
  • 大数据

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

    93 引用 • 113 回帖 • 1 关注
  • SSL

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

    70 引用 • 193 回帖 • 461 关注
  • 一些有用的避坑指南。

    69 引用 • 93 回帖
  • Solo

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

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

    1429 引用 • 10050 回帖 • 486 关注
  • Caddy

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

    11 引用 • 54 回帖 • 146 关注
  • ReactiveX

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

    1 引用 • 2 回帖 • 143 关注
  • AngularJS

    AngularJS 诞生于 2009 年,由 Misko Hevery 等人创建,后为 Google 所收购。是一款优秀的前端 JS 框架,已经被用于 Google 的多款产品当中。AngularJS 有着诸多特性,最为核心的是:MVC、模块化、自动化双向数据绑定、语义化标签、依赖注入等。2.0 版本后已经改名为 Angular。

    12 引用 • 50 回帖 • 457 关注
  • JVM

    JVM(Java Virtual Machine)Java 虚拟机是一个微型操作系统,有自己的硬件构架体系,还有相应的指令系统。能够识别 Java 独特的 .class 文件(字节码),能够将这些文件中的信息读取出来,使得 Java 程序只需要生成 Java 虚拟机上的字节码后就能在不同操作系统平台上进行运行。

    180 引用 • 120 回帖 • 3 关注
  • 游戏

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

    174 引用 • 814 回帖
  • 服务

    提供一个服务绝不仅仅是简单的把硬件和软件累加在一起,它包括了服务的可靠性、服务的标准化、以及对服务的监控、维护、技术支持等。

    41 引用 • 24 回帖 • 2 关注
  • 创造

    你创造的作品可能会帮助到很多人,如果是开源项目的话就更赞了!

    175 引用 • 994 回帖
  • Sublime

    Sublime Text 是一款可以用来写代码、写文章的文本编辑器。支持代码高亮、自动完成,还支持通过插件进行扩展。

    10 引用 • 5 回帖 • 2 关注
  • C++

    C++ 是在 C 语言的基础上开发的一种通用编程语言,应用广泛。C++ 支持多种编程范式,面向对象编程、泛型编程和过程化编程。

    106 引用 • 152 回帖 • 2 关注
  • API

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

    76 引用 • 429 回帖 • 5 关注
  • TensorFlow

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

    20 引用 • 19 回帖 • 3 关注
  • 生活

    生活是指人类生存过程中的各项活动的总和,范畴较广,一般指为幸福的意义而存在。生活实际上是对人生的一种诠释。生活包括人类在社会中与自己息息相关的日常活动和心理影射。

    230 引用 • 1454 回帖
  • WebComponents

    Web Components 是 W3C 定义的标准,它给了前端开发者扩展浏览器标签的能力,可以方便地定制可复用组件,更好的进行模块化开发,解放了前端开发者的生产力。

    1 引用 • 1 关注
  • 酷鸟浏览器

    安全 · 稳定 · 快速
    为跨境从业人员提供专业的跨境浏览器

    3 引用 • 59 回帖 • 18 关注
  • Flutter

    Flutter 是谷歌的移动 UI 框架,可以快速在 iOS 和 Android 上构建高质量的原生用户界面。 Flutter 可以与现有的代码一起工作,它正在被越来越多的开发者和组织使用,并且 Flutter 是完全免费、开源的。

    39 引用 • 92 回帖 • 8 关注
  • CodeMirror
    1 引用 • 2 回帖 • 127 关注
  • jQuery

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

    63 引用 • 134 回帖 • 728 关注
  • SEO

    发布对别人有帮助的原创内容是最好的 SEO 方式。

    35 引用 • 200 回帖 • 25 关注