问题描述
如上图。我从别处导出一个名为 fp.sy 的压缩包文件,然后把它导入到另一个 siyuan 客户端,导入步骤是:我先在 siyuan 客户端中新建笔记本,命名为 fp;然后导入 fp.sy 的压缩包到该笔记本
出现如下问题:
在新的 siyuan 客户端中,调整 fp 笔记本下的文档排列顺序,然后出现上述图中的文件已存在问题;
但是,在该 fp 笔记本中新建文档,然后移动新建文档,不存在“文件已存在的问题”。
如上图。我从别处导出一个名为 fp.sy 的压缩包文件,然后把它导入到另一个 siyuan 客户端,导入步骤是:我先在 siyuan 客户端中新建笔记本,命名为 fp;然后导入 fp.sy 的压缩包到该笔记本
出现如下问题:
在新的 siyuan 客户端中,调整 fp 笔记本下的文档排列顺序,然后出现上述图中的文件已存在问题;
但是,在该 fp 笔记本中新建文档,然后移动新建文档,不存在“文件已存在的问题”。
现在的情况是:siyuan2 客户端部署在 linux mint 上的 docker,而移动文件排序产生“文件已存在”的问题。【这个问题产生的原因:就是我有两个 siyuan1、siyuan2 运行在 docker,且他们的工作空间是独立的。我在网页端把 siyuan1 的文件导出,再到网页端导入到 siyuan2】
如下图所示,我在 siyuan2 客户端把 2022-11-11 文档移动到 2022-11-14 上方,立马报错,来回移动两个文件顺讯,一直报错,但是文件顺序的确能移动了。只是不爽!
随后做了如下测试:
将 siyuan2 的数据同步到云端后,关闭容器:sudo docker stop siyuan2。
再在 win10 上安装全新的 siyuan 2.5.0 客户端,,从云端同步数据库,同步完毕后,win10 客户端移动同样的文件:将 2022-11-11 和 2022-11-14 来回移动顺序,不会出错——不会出现“文件已存在”的问题。如下图
同步,退出 win10 siyuan。
在 linux 上,再 run 一个新的 siyuan3 客户端(开辟全新、独立的工作空间),导入秘钥、并把云端数据同步下来,再来回移动同样的文件的顺序(2022-11-11 和 2022-11-15),又出现文件已存在的问题。
综上,我认为原因可能是:
我认为,背后原因可能是,我导出的内容,有跨笔记本引用。
我导出的 siyuan1 客户端中的 fp 笔记本,但是 fp 中某些笔记引用了 siyuan1 中的其他笔记本中的内容。这样把到处的 fp 导入到 siyuan2 客户端:可能导致上述问题,
另外我还发现,导入到 siyuan2 中的 fp 笔记本内的某些文档丢失名字,成为 Untitle。
我想导出,是因为担心数据量越来越大后,影响索引效率。
请教下,如果未来数据量太大,我还想保持高速索引,可以通过使用更强大的 cpu(多核心、更高主频)和更大内存来并行查找索引中内容来提高效率吗?
我粗略了解一些数据库索引原理,关键就是在内存中查找数据。那理论上性能更强劲 cpu 配合更大内存,可以解决索引问题?
如果我的想法正确,那我就不使用导出功能了,将来数据量太大影响检索效率,上更强劲的 cpu、更大频率更高的内存即可解决,就不用把数据分拆到好几个 siyuan 客户端了。
我现在用着索引太爽了,就怕将来不爽了痛苦。所以现在就得想好到底是把数据分开来,还是将来上更强劲的硬件。
刚刚我测试了跨笔记本引用再导出,也没有能重现问题,跨笔记本会把引用的文档一并导出的。
至于性能问题,任何软件都有一定的上限,但是作为前期使用不必太有顾虑,可以按照一个月或者三个月这样的周期测算一下数据增长情况,然后预估按照这个增长能够支持多久,如果是几年的话我觉得近期就没有必要太在乎性能影响了,几年以后升级一下硬件可能就解决问题了。
如果实在有顾虑,建议通过拆分笔记本或者工作空间来使用,但是我个人觉得这样用的话比较累,而且过度的分类规则也是种自我设限,没有太大必要。
对于数据库的性能,在个人电脑上差不多就是几十万到百万条记录差不多能够在可以接受的性能范围内,再多的话我觉得也没有多少工具能够支持全文搜索了,不信的话你可以找一些笔记软件测试一下性能,当文档数量上万以后看看全文搜索的性能差异,我相信思源还是很难能打的。
IBM(国际商业机器公司)或万国商业机器公司,简称 IBM(International Business Machines Corporation),总公司在纽约州阿蒙克市。1911 年托马斯·沃森创立于美国,是全球最大的信息技术和业务解决方案公司,拥有全球雇员 30 多万人,业务遍及 160 多个国家和地区。
Gitea 是一个开源社区驱动的轻量级代码托管解决方案,后端采用 Go 编写,采用 MIT 许可证。
脑图又叫思维导图,是表达发散性思维的有效图形思维工具 ,它简单却又很有效,是一种实用性的思维工具。
WebSocket 是 HTML5 中定义的一种新协议,它实现了浏览器与服务器之间的全双工通信(full-duplex)。
1999 年 2 月腾讯正式推出“腾讯 QQ”,在线用户由 1999 年的 2 人(马化腾和张志东)到现在已经发展到上亿用户了,在线人数超过一亿,是目前使用最广泛的聊天软件之一。
etcd 是一个分布式、高可用的 key-value 数据存储,专门用于在分布式系统中保存关键数据。
SQL Server 是由 [微软] 开发和推广的关系数据库管理系统(DBMS),它最初是由 微软、Sybase 和 Ashton-Tate 三家公司共同开发的,并于 1988 年推出了第一个 OS/2 版本。
SpaceVim 是一个社区驱动的模块化 vim/neovim 配置集合,以模块的方式组织管理插件以
及相关配置,为不同的语言开发量身定制了相关的开发模块,该模块提供代码自动补全,
语法检查、格式化、调试、REPL 等特性。用户仅需载入相关语言的模块即可得到一个开箱
即用的 Vim-IDE。
FreeMarker 是一款好用且功能强大的 Java 模版引擎。
服务器,也称伺服器,是提供计算服务的设备。由于服务器需要响应服务请求,并进行处理,因此一般来说服务器应具备承担服务并且保障服务的能力。
Web Components 是 W3C 定义的标准,它给了前端开发者扩展浏览器标签的能力,可以方便地定制可复用组件,更好的进行模块化开发,解放了前端开发者的生产力。
HHKB 是富士通的 Happy Hacking 系列电容键盘。电容键盘即无接点静电电容式键盘(Capacitive Keyboard)。
知乎是网络问答社区,连接各行各业的用户。用户分享着彼此的知识、经验和见解,为中文互联网源源不断地提供多种多样的信息。
智能合约(Smart contract)是一种旨在以信息化方式传播、验证或执行合同的计算机协议。智能合约允许在没有第三方的情况下进行可信交易,这些交易可追踪且不可逆转。智能合约概念于 1994 年由 Nick Szabo 首次提出。
Ant Design 是服务于企业级产品的设计体系,基于确定和自然的设计价值观上的模块化解决方案,让设计者和开发者专注于更好的用户体验。
各种网址链接、内容导航。
uTools 是一个极简、插件化、跨平台的现代桌面软件。通过自由选配丰富的插件,打造你得心应手的工具集合。
应用程序编程接口(Application Programming Interface)是一些预先定义的函数,目的是提供应用程序与开发人员基于某软件或硬件得以访问一组例程的能力,而又无需访问源码,或理解内部工作机制的细节。
C++ 是在 C 语言的基础上开发的一种通用编程语言,应用广泛。C++ 支持多种编程范式,面向对象编程、泛型编程和过程化编程。
Flutter 是谷歌的移动 UI 框架,可以快速在 iOS 和 Android 上构建高质量的原生用户界面。 Flutter 可以与现有的代码一起工作,它正在被越来越多的开发者和组织使用,并且 Flutter 是完全免费、开源的。
心是产生任何想法的源泉,心本体会陷入到对自己本体不能理解的状态中,因为心能产生任何想法,不能分出对错,不能分出自己。
Love2D 是一个开源的, 跨平台的 2D 游戏引擎。使用纯 Lua 脚本来进行游戏开发。目前支持的平台有 Windows, Mac OS X, Linux, Android 和 iOS。
小说是以刻画人物形象为中心,通过完整的故事情节和环境描写来反映社会生活的文学体裁。
哪里都缺人,哪里都不缺人。
欢迎来到这里!
我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。
注册 关于