- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在构建一个应用程序,允许人们标记他们何时可用/不可用,并允许其他人在此期间进行约会。但是,当有人进行搜索时,我无法找到一种存储和查询可用性的好方法。
例如:
存储和查询数据的有效方法是什么?
其他注意事项:
最佳答案
我显然会利用 date_range
data type (介绍 here )。您可以为每个主机和该主机的每个可用性创建一个文档(或者,如果您想要更细粒度的数据,则每小时一个可用性)。鉴于您的上述要求,它看起来像这样:
首先创建索引和映射:
PUT hosts
{
"mappings": {
"properties": {
"name": {
"type": "keyword"
},
"availability": {
"type": "date_range"
}
}
}
}
然后添加您的主机的可用性(我决定使用 GMT 时区,因此时间与您上面提到的时间 1:1 匹配):
PUT hosts/_doc/_bulk
{"index": {}}
{ "name": "A", "availability": { "gte": "2019-10-01T07:00:00.000Z", "lte": "2019-10-01T12:00:00.000Z" }}
{"index": {}}
{ "name": "A", "availability": { "gte": "2019-10-01T13:00:00.000Z", "lte": "2019-10-01T16:00:00.000Z" }}
{"index": {}}
{ "name": "A", "availability": { "gte": "2019-10-03T07:00:00.000Z", "lte": "2019-10-03T16:00:00.000Z" }}
{"index": {}}
{ "name": "A", "availability": { "gte": "2019-10-08T07:00:00.000Z", "lte": "2019-10-08T16:00:00.000Z" }}
{"index": {}}
{ "name": "A", "availability": { "gte": "2019-10-11T09:00:00.000Z", "lte": "2019-10-11T10:00:00.000Z" }}
{"index": {}}
{ "name": "A", "availability": { "gte": "2019-10-11T12:00:00.000Z", "lte": "2019-10-11T18:00:00.000Z" }}
{"index": {}}
{ "name": "B", "availability": { "gte": "2019-10-01T09:00:00.000Z", "lte": "2019-10-01T20:00:00.000Z" }}
{"index": {}}
{ "name": "B", "availability": { "gte": "2019-10-04T09:00:00.000Z", "lte": "2019-10-04T20:00:00.000Z" }}
{"index": {}}
{ "name": "B", "availability": { "gte": "2019-10-05T09:00:00.000Z", "lte": "2019-10-05T20:00:00.000Z" }}
{"index": {}}
{ "name": "B", "availability": { "gte": "2019-10-06T09:00:00.000Z", "lte": "2019-10-06T20:00:00.000Z" }}
然后使用 range
query 查询就很容易了:
User C is searching for any availability on Oct 6-8 from 4pm to 6pm, so should see only host B
POST hosts/_search
{
"query": {
"bool": {
"should": [
{
"range": {
"availability": {
"gte": "2019-10-06T16:00:00.000Z",
"lte": "2019-10-06T18:00:00.000Z",
"relation": "contains"
}
}
},
{
"range": {
"availability": {
"gte": "2019-10-07T16:00:00.000Z",
"lte": "2019-10-07T18:00:00.000Z",
"relation": "contains"
}
}
},
{
"range": {
"availability": {
"gte": "2019-10-08T16:00:00.000Z",
"lte": "2019-10-08T18:00:00.000Z",
"relation": "contains"
}
}
}
]
}
}
}
结果:只有主机 B =>
{
"_index" : "hosts",
"_type" : "_doc",
"_id" : "KzOggG0BzetAdRPqckxN",
"_score" : 1.0,
"_source" : {
"name" : "B",
"availability" : {
"gte" : "2019-10-06T09:00:00.000Z",
"lte" : "2019-10-06T20:00:00.000Z"
}
}
}
User D is searching for any availability on Oct 9-12 from 9am to 1pm, so should see only host A
POST hosts/_search
{
"query": {
"bool": {
"should": [
{
"range": {
"availability": {
"gte": "2019-10-09T09:00:00.000Z",
"lte": "2019-10-09T13:00:00.000Z",
"relation": "intersects"
}
}
},
{
"range": {
"availability": {
"gte": "2019-10-10T09:00:00.000Z",
"lte": "2019-10-10T13:00:00.000Z",
"relation": "intersects"
}
}
},
{
"range": {
"availability": {
"gte": "2019-10-11T09:00:00.000Z",
"lte": "2019-10-11T13:00:00.000Z",
"relation": "intersects"
}
}
},
{
"range": {
"availability": {
"gte": "2019-10-12T09:00:00.000Z",
"lte": "2019-10-12T13:00:00.000Z",
"relation": "intersects"
}
}
}
]
}
}
}
结果:只有主机A =>
{
"_index" : "hosts",
"_type" : "_doc",
"_id" : "JzOggG0BzetAdRPqckxN",
"_score" : 1.0,
"_source" : {
"name" : "A",
"availability" : {
"gte" : "2019-10-11T12:00:00.000Z",
"lte" : "2019-10-11T18:00:00.000Z"
}
}
},
{
"_index" : "hosts",
"_type" : "_doc",
"_id" : "JjOggG0BzetAdRPqckxN",
"_score" : 1.0,
"_source" : {
"name" : "A",
"availability" : {
"gte" : "2019-10-11T09:00:00.000Z",
"lte" : "2019-10-11T10:00:00.000Z"
}
}
}
User E is searching for availability with Host A on October 1st, so should be able to make a 1 hour appointment at any from 7am to 11am, and from 1pm to 4pm
POST hosts/_search
{
"query": {
"bool": {
"filter": [
{
"term": {
"name": "A"
}
},
{
"range": {
"availability": {
"gte": "2019-10-01",
"lt": "2019-10-02",
"relation": "intersects"
}
}
}
]
}
}
}
结果:主持人 A 早上 7 点到 12 点和下午 1 点到 4 点 =>
{
"_index" : "hosts",
"_type" : "_doc",
"_id" : "IjOggG0BzetAdRPqckxN",
"_score" : 0.0,
"_source" : {
"name" : "A",
"availability" : {
"gte" : "2019-10-01T07:00:00.000Z",
"lte" : "2019-10-01T12:00:00.000Z"
}
}
},
{
"_index" : "hosts",
"_type" : "_doc",
"_id" : "IzOggG0BzetAdRPqckxN",
"_score" : 0.0,
"_source" : {
"name" : "A",
"availability" : {
"gte" : "2019-10-01T13:00:00.000Z",
"lte" : "2019-10-01T16:00:00.000Z"
}
}
}
关于database - 如何正确存储和查询可用性数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58107486/
是否可以使用 JHipster 5(带有 Spring Boot 2)?我注意到在发行说明中提到了 JHipster 5 的工作,但看不到任何关于如何安装/运行 5 的“预览”版本的信息。 最佳答案
使用多个显示器时,有没有办法拆分 Xcode 界面? 我有 2 台显示器,但仍然没有找到一种简单的方法在超过 1 台显示器上使用它(左侧的 Storyboard,右侧的代码) - 就像在 Androi
我正在尝试处理 uwp 应用程序中的 xml,我添加了引用和用法: using System.Xml; using System.Xml.XPath; 但是 private XmlDocument d
JSunit 真的是 Junit 到 Javascript 的直接端口吗?所以我听说过,但我想知道为什么我的公司没有使用它。我的公司有很多聪明人,所以如果我们不使用它,我想知道 Jsunit 作为 j
当使用原始 TCP 套接字时,需要进行消息帧化,如 here 所述,带有长度前缀或分隔符。 我今天遇到了“SOCK_SEQPACKET”套接字选项,它显然可以几乎透明地进行消息框架。 目前“SOCK_
我在一个小型开发小组工作。我们正在构建和改进我们的产品。 半年前我们无法考虑更高的特性,比如可用性,因为我们的产品有很多问题。许多错误、高技术债务、低性能和其他问题使我们无法专注于可用性。 随着时间的
是否可以通过编程方式控制@RestController来启用或禁用它?我不想只在每个 @RequestMapping 方法中编写代码来执行某种 if (!enabled) { return 404Ex
azure 的 blob 在被新版本覆盖时是否可供下载? 根据我使用 Cloud Storage Studio 的测试,下载被阻止,直到覆盖完成,但是我的测试来自同一台计算机,因此我无法确定这是正确的
我一直认为(但出于某种原因从未实践过)动态生成且仅包含一个项目的下拉菜单应该自动选择该项目。这与我观察到的典型方法相反,即在顶部创建一个空白条目,您仍然必须与菜单交互以进行单个可用选择。 例如,当我登
我正在为我的兄弟编写一个基于 Web 的小实用程序,他需要合并 CSV 文件中的列。我知道这样的事情肯定存在于某个地方,但这很大程度上是因为这是一个有趣的小练习。 无论如何,我正在尝试找出最好/最简洁
如您所知,pinterest api 现在似乎已关闭。( api.pinterest.com )在此站点中:http://tijn.bo.lt/pinterest-api ,它表示只读访问仍然有效。到
我想为公寓可用性应用程序制作日历 View 。我的想法是从 MySQL 数据库获取日期范围(不可用日期)并将其显示在日历 View 中。我的日历 View 应该有 3 种不同的样式: 可用日期 不可用
我究竟应该如何配置我的广播接收器以使我的应用程序响应 wifi 可用性的变化。不过,当应用程序未运行时,我并不真正关心对此使用react。 我在这里试图完成的是,当应用程序运行时,我需要使本地数据库与
在我的网络应用程序中,我有 parent 和保姆。 保姆将声明工作时间(时间间隔),该工作时间将存储在工作时间表中。 家长也会每隔一段时间表达自己的需求(暂时不需要存储)。 所以我设计了这样的可用性表
概览 我希望在 CloudKit 无法访问时收到通知。 CloudKit 可能无法访问的可能场景: CloudKit 服务器不可访问 互联网连接不可用。 迄今为止所做的尝试: 观察 CKAccount
好的,我有我为核心数据创建的类 LoginPass.h 然后我有头等舱 FirstClass.h 然后我需要在 SecondClass 中使用这些类,我在其中使用 @class 声明它们。头文件 Se
例如 linux kernel-2.6.32-279 没有在/usr/include/asm-generic/socket.h 中定义 SO_REUSEPORT 但 kernel-2.6.32-431
我正在尝试安装的工具说: MySQL server data directory needs to reside on an LVM volume 如何检查我的数据目录是否在 LVM 上? 最佳答案
这个问题在这里已经有了答案: 关闭 11 年前。 Possible Duplicate: Programmatically find device support GPS or not? 如何检查设
我听说汽车行业有一种叫做 MISRA C 的东西。 其他高可靠性/可用性/安全性行业的相关标准是什么,例如 空间 飞机 银行/金融 汽车 医疗 国防/军事 ??? -亚当 最佳答案 查看戈达德太空飞行
我是一名优秀的程序员,十分优秀!