在 cosmos db 中使用 UDF 进行日期转换
Posted
技术标签:
【中文标题】在 cosmos db 中使用 UDF 进行日期转换【英文标题】:Date conversion using UDF in cosmos db 【发布时间】:2020-08-17 07:06:29 【问题描述】:我的日期是字符串,像这样 2020 年 7 月 13 日 如何使用 用户定义函数 或 javascript"2020-10-07T00:00:00.000Z" /p>
【问题讨论】:
请做一些研究。 *** 上有大量相关问题。 【参考方案1】:您可以使用 String.split() 将日期拆分为其组成部分,然后使用 Date.UTC 转换为 unix 时间。注意:我假设您的日期 2020 年 7 月 13 日是 UTC。如果是当地时间,我们会使用 new Date(year, month, day) 代替。
// Use this if your date string refers to UTC time
function parseUTCTimestamp(s)
const monthIndexes =
jan:0, feb:1, mar:2, apr:3, may:4, jun:5,
jul:6, aug:7, sep:8, oct:9, nov:10, dec:11
;
const [day, month, year] = s.toLowerCase().split('-');
return new Date(Date.UTC(year, monthIndexes[month], day)).toISOString();
console.log("UTC:", parseUTCTimestamp("13-Jul-2020"));
console.log("UTC:", parseUTCTimestamp("17-aug-2020"));
// Use this if your date string refers to local time
function parseLocalTimestamp(s)
const monthIndexes =
jan:0, feb:1, mar:2, apr:3, may:4, jun:5,
jul:6, aug:7, sep:8, oct:9, nov:10, dec:11
;
const [day, month, year] = s.toLowerCase().split('-');
return new Date(year, monthIndexes[month], day).toISOString();
console.log("Local:", parseLocalTimestamp("13-Jul-2020"));
console.log("Local:", parseLocalTimestamp("17-aug-2020"));
【讨论】:
以上是关于在 cosmos db 中使用 UDF 进行日期转换的主要内容,如果未能解决你的问题,请参考以下文章
如何使用 LINQ 针对 Azure Cosmos Document DB SQL API 有效地进行动态查询?
Cosmos db 使用 Java SDK 部分更新 SQL api
有没有办法在查询 Cosmos Db 中对数据进行逻辑分区?就像您可以使用散列和模函数一样[关闭]