v3.0.9 数据库获取列数据的问题

本贴最后更新于 417 天前,其中的信息可能已经时移俗易

image.png

如上图,设计了一个简单的阅读耗时统计。但是在获取列数据的时候,如果该列没有数据,变量就会失效。也就说无法将变量提升(需要重复定义)。不确定是我代码写的不对还是笔记的 bug
以下是我的代码:

.action{$readState := index .状态} .action{$today := (now | date "2006-01-02")} .action{$nowdate :=(toDate "2006-01-02" $today)} .action{if eq $readState "想读"} 🟡未读 .action{else if eq $readState "在读"} .action{$deadline := index .截止日期} .action{$delta :=(div ($nowdate.Sub $deadline).Hours 24)} .action{if lt $delta 0} .action{$startTime := index .开始日期} .action{$current :=(div ($nowdate.Sub $startTime).Hours 24)} .action{$current} 天 .action{else} 🔴超时.action{$delta} 天 .action{end} .action{else} .action{$startTime := index .开始日期} .action{$endTime := index .结束日期} .action{$delta :=(div ($endTime.Sub $startTime).Hours 24)} .action{$delta} 天 .action{end}

可以看到需要重复定义 $startTime 等变量,如果在最外面定义 $startTime,$endTime 等变量,如果该变量未设定值,则会无法正常显示耗时,如下:

.action{$readState := index .状态} .action{$today := (now | date "2006-01-02")} .action{$nowdate :=(toDate "2006-01-02" $today)} .action{$startTime := index .开始日期} .action{$endTime := index .结束日期} .action{$deadline := index .截止日期} .action{if eq $readState "想读"} 🟡未读 .action{else if eq $readState "在读"} .action{$delta :=(div ($nowdate.Sub $deadline).Hours 24)} .action{if lt $delta 0} .action{$startTime := index .开始日期} .action{$current :=(div ($nowdate.Sub $startTime).Hours 24)} .action{$current} 天 .action{else} 🔴超时.action{$delta} 天 .action{end} .action{else} .action{$delta :=(div ($endTime.Sub $startTime).Hours 24)} .action{$delta} 天 .action{end}

image.png

希望有大佬可以解惑,可能是我对语法不够熟悉。

  • 思源笔记

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

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

    25771 引用 • 106684 回帖
  • Q&A

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

    9883 引用 • 44937 回帖 • 79 关注

相关帖子

被采纳的回答
  • 试试这个,有用请采纳:

    .action{$readState := index . "状态"} .action{if eq $readState "想读"} 🟡未读 .action{else} .action{$endTime := index . "结束日期"} .action{if empty $endTime}.action{/* 如果结束日期为空 */} .action{$nowdate := (now | date "2006-01-02")}.action{/* 当前日期 */} .action{$nowdate = toDate "2006-01-02" $nowdate | date "2006-01-02"} .action{$deadline := (index . "截止日期" | date "2006-01-02")} .action{$deadline = toDate "2006-01-02" $deadline | date "2006-01-02"} .action{if le $nowdate $deadline}.action{/* 如果当前日期小于截止日期,就计算开始日期到当前日期 */} .action{$nowdate := (now | date "2006-01-02")} .action{$nowdate = toDate "2006-01-02" $nowdate} .action{$startTime := (index . "开始日期" | date "2006-01-02")} .action{$startTime = toDate "2006-01-02" $startTime} .action{$current :=(div ($nowdate.Sub $startTime).Hours 24)} .action{$current} 天 .action{else if gt $nowdate $deadline}.action{/* 如果当前日期大于等于截止日期,就计算超时 */} .action{$nowdate := (now | date "2006-01-02")} .action{$nowdate = toDate "2006-01-02" $nowdate} .action{$deadline := (index . "截止日期" | date "2006-01-02")} .action{$deadline = toDate "2006-01-02" $deadline} .action{$delta :=(div ($nowdate.Sub $deadline).Hours 24)} 🔴超时 .action{$delta} 天 .action{end} .action{else}.action{/* 如果有结束日期,就计算开始日期到结束日期 */} .action{$endTime := (index . "结束日期" | date "2006-01-02")} .action{$endTime = toDate "2006-01-02" $endTime} .action{$startTime := (index . "开始日期" | date "2006-01-02")} .action{$startTime = toDate "2006-01-02" $startTime} .action{$current :=(div ($endTime.Sub $startTime).Hours 24)} .action{$current} 天 .action{end} .action{end}

欢迎来到这里!

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

注册 关于
请输入回帖内容 ...
  • White-Night-Dream via Android

    试试浮点函数(divf)

    1 回复
  • museum via macOS

    这样子嘛
    .action{$delta :=(divf ($endTime.Sub $startTime).Hours 24)}

    好像不行哦

  • 试试这个,有用请采纳:

    .action{$readState := index . "状态"} .action{if eq $readState "想读"} 🟡未读 .action{else} .action{$endTime := index . "结束日期"} .action{if empty $endTime}.action{/* 如果结束日期为空 */} .action{$nowdate := (now | date "2006-01-02")}.action{/* 当前日期 */} .action{$nowdate = toDate "2006-01-02" $nowdate | date "2006-01-02"} .action{$deadline := (index . "截止日期" | date "2006-01-02")} .action{$deadline = toDate "2006-01-02" $deadline | date "2006-01-02"} .action{if le $nowdate $deadline}.action{/* 如果当前日期小于截止日期,就计算开始日期到当前日期 */} .action{$nowdate := (now | date "2006-01-02")} .action{$nowdate = toDate "2006-01-02" $nowdate} .action{$startTime := (index . "开始日期" | date "2006-01-02")} .action{$startTime = toDate "2006-01-02" $startTime} .action{$current :=(div ($nowdate.Sub $startTime).Hours 24)} .action{$current} 天 .action{else if gt $nowdate $deadline}.action{/* 如果当前日期大于等于截止日期,就计算超时 */} .action{$nowdate := (now | date "2006-01-02")} .action{$nowdate = toDate "2006-01-02" $nowdate} .action{$deadline := (index . "截止日期" | date "2006-01-02")} .action{$deadline = toDate "2006-01-02" $deadline} .action{$delta :=(div ($nowdate.Sub $deadline).Hours 24)} 🔴超时 .action{$delta} 天 .action{end} .action{else}.action{/* 如果有结束日期,就计算开始日期到结束日期 */} .action{$endTime := (index . "结束日期" | date "2006-01-02")} .action{$endTime = toDate "2006-01-02" $endTime} .action{$startTime := (index . "开始日期" | date "2006-01-02")} .action{$startTime = toDate "2006-01-02" $startTime} .action{$current :=(div ($endTime.Sub $startTime).Hours 24)} .action{$current} 天 .action{end} .action{end}
    1 回复
  • Liuzn 1
    .action{$endTime := index . "结束日期"}

    应该用这个,注意 . 前后都有空格,这样写在最前面也是没问题的。

    其他应该没问题,当然最好都统一改一下

    还有就是状态一栏其实也可以用模板列,根据日期自动显示状态

    1 回复
  • museum via macOS

    谢谢!

  • museum via macOS

    非常感谢!

  • 做了第二版,不需要[状态]单选列:

    image.png

    .action{/* 第二版,不需要[状态]单选列 */} .action{ $deadline := index . "截止日期" } .action{ $start := index . "开始日期" } .action{ $end := index . "结束日期" } .action{ if $end } .action{ if $start } 总共 .action{ div ($end.Sub $start).Hours 24 } 天 .action{ else } 无计数 .action{ end } .action{ else } .action{ $now := now } .action{ $nowStr := toString $now } .action{ if $deadline } .action{ $deadlineStr := toString $deadline } .action{ if gt $nowStr $deadlineStr } 逾期 .action{ div ($now.Sub $deadline).Hours 24 } 天 .action{ else } .action{ if $start } 已读 .action{ div ($now.Sub $start).Hours 24 } 天 , .action{ end } 剩余 .action{ div ($deadline.Sub $now).Hours 24 } 天 .action{ end } .action{ else } .action{ if $start } .action{ $startStr := toString $start } .action{ if gt $nowStr $startStr } 已读 .action{ div ($now.Sub $start).Hours 24 } 天 .action{ else } 未开始 .action{ end } .action{ else } 待定 .action{ end } .action{ end } .action{ end }
    逻辑: 如果有结束日期 如果有开始日期 → 计算开始日期到结束日期 → 总共 N 天 如果没有开始日期 → 无计数 如果没有结束日期 如果有截止日期 如果当前日期大于截止日期 → 计算截止日期到当前日期 → 逾期 N 天 否则 如果有开始日期 计算开始日期到当前日期, → 已读 N 天, 计算当前日期到截止日期 → 剩余 N 天 如果没有截止日期 如果有开始日期 如果当前日期大于开始日期 计算开始日期到当前日期 → 已读 N 天 否则 未开始 如果没有开始日期 待定
    1 回复
    2 操作
    JeffreyChen 在 2024-05-15 19:26:06 更新了该回帖
    JeffreyChen 在 2024-05-15 19:24:39 更新了该回帖
  • museum via macOS

    哈哈,太优秀了,最近没有有点忙没看论坛,非常感谢!!!

  • 关联以后能不呢让这个求和所关联数据库指定行的合?

请输入回帖内容 ...

推荐标签 标签

  • 小说

    小说是以刻画人物形象为中心,通过完整的故事情节和环境描写来反映社会生活的文学体裁。

    32 引用 • 108 回帖
  • BAE

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

    19 引用 • 75 回帖 • 677 关注
  • 区块链

    区块链是分布式数据存储、点对点传输、共识机制、加密算法等计算机技术的新型应用模式。所谓共识机制是区块链系统中实现不同节点之间建立信任、获取权益的数学算法 。

    92 引用 • 752 回帖
  • 单点登录

    单点登录(Single Sign On)是目前比较流行的企业业务整合的解决方案之一。SSO 的定义是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统。

    9 引用 • 25 回帖 • 3 关注
  • Git

    Git 是 Linux Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。

    211 引用 • 358 回帖
  • Follow
    4 引用 • 12 回帖 • 4 关注
  • 音乐

    你听到信仰的声音了么?

    62 引用 • 512 回帖 • 2 关注
  • Python

    Python 是一种面向对象、直译式电脑编程语言,具有近二十年的发展历史,成熟且稳定。它包含了一组完善而且容易理解的标准库,能够轻松完成很多常见的任务。它的语法简捷和清晰,尽量使用无异义的英语单词,与其它大多数程序设计语言使用大括号不一样,它使用缩进来定义语句块。

    554 引用 • 675 回帖
  • 域名

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

    43 引用 • 208 回帖 • 1 关注
  • Sym

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

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

    524 引用 • 4601 回帖 • 709 关注
  • HBase

    HBase 是一个分布式的、面向列的开源数据库,该技术来源于 Fay Chang 所撰写的 Google 论文 “Bigtable:一个结构化数据的分布式存储系统”。就像 Bigtable 利用了 Google 文件系统所提供的分布式数据存储一样,HBase 在 Hadoop 之上提供了类似于 Bigtable 的能力。

    17 引用 • 6 回帖 • 63 关注
  • Swagger

    Swagger 是一款非常流行的 API 开发工具,它遵循 OpenAPI Specification(这是一种通用的、和编程语言无关的 API 描述规范)。Swagger 贯穿整个 API 生命周期,如 API 的设计、编写文档、测试和部署。

    26 引用 • 35 回帖 • 4 关注
  • Vue.js

    Vue.js(读音 /vju ː/,类似于 view)是一个构建数据驱动的 Web 界面库。Vue.js 的目标是通过尽可能简单的 API 实现响应的数据绑定和组合的视图组件。

    268 引用 • 666 回帖
  • Hibernate

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

    39 引用 • 103 回帖 • 726 关注
  • webpack

    webpack 是一个用于前端开发的模块加载器和打包工具,它能把各种资源,例如 JS、CSS(less/sass)、图片等都作为模块来使用和处理。

    42 引用 • 130 回帖 • 251 关注
  • Flume

    Flume 是一套分布式的、可靠的,可用于有效地收集、聚合和搬运大量日志数据的服务架构。

    9 引用 • 6 回帖 • 655 关注
  • ZeroNet

    ZeroNet 是一个基于比特币加密技术和 BT 网络技术的去中心化的、开放开源的网络和交流系统。

    1 引用 • 21 回帖 • 649 关注
  • 互联网

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

    98 引用 • 367 回帖
  • SpaceVim

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

    3 引用 • 31 回帖 • 112 关注
  • Sillot

    Insights(注意当前设置 master 为默认分支)

    汐洛彖夲肜矩阵(Sillot T☳Converbenk Matrix),致力于服务智慧新彖乄,具有彖乄驱动、极致优雅、开发者友好的特点。其中汐洛绞架(Sillot-Gibbet)基于自思源笔记(siyuan-note),前身是思源笔记汐洛版(更早是思源笔记汐洛分支),是智慧新录乄终端(多端融合,移动端优先)。

    主仓库地址:Hi-Windom/Sillot

    文档地址:sillot.db.sc.cn

    注意事项:

    1. ⚠️ 汐洛仍在早期开发阶段,尚不稳定
    2. ⚠️ 汐洛并非面向普通用户设计,使用前请了解风险
    3. ⚠️ 汐洛绞架基于思源笔记,开发者尽最大努力与思源笔记保持兼容,但无法实现 100% 兼容
    29 引用 • 25 回帖 • 117 关注
  • 开源

    Open Source, Open Mind, Open Sight, Open Future!

    411 引用 • 3588 回帖 • 1 关注
  • Firefox

    Mozilla Firefox 中文俗称“火狐”(正式缩写为 Fx 或 fx,非正式缩写为 FF),是一个开源的网页浏览器,使用 Gecko 排版引擎,支持多种操作系统,如 Windows、OSX 及 Linux 等。

    7 引用 • 30 回帖 • 385 关注
  • 服务器

    服务器,也称伺服器,是提供计算服务的设备。由于服务器需要响应服务请求,并进行处理,因此一般来说服务器应具备承担服务并且保障服务的能力。

    125 引用 • 585 回帖
  • Q&A

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

    9883 引用 • 44937 回帖 • 79 关注
  • Anytype
    3 引用 • 31 回帖 • 24 关注
  • HTML

    HTML5 是 HTML 下一个的主要修订版本,现在仍处于发展阶段。广义论及 HTML5 时,实际指的是包括 HTML、CSS 和 JavaScript 在内的一套技术组合。

    108 引用 • 295 回帖
  • 七牛云

    七牛云是国内领先的企业级公有云服务商,致力于打造以数据为核心的场景化 PaaS 服务。围绕富媒体场景,七牛先后推出了对象存储,融合 CDN 加速,数据通用处理,内容反垃圾服务,以及直播云服务等。

    29 引用 • 230 回帖 • 124 关注