Skip to content

Commit

Permalink
Add sort format for timestamp field to support sort and search values…
Browse files Browse the repository at this point in the history
… in millis.
  • Loading branch information
fmassot committed Dec 5, 2023
1 parent f08dc8b commit 0a6e45e
Show file tree
Hide file tree
Showing 14 changed files with 600 additions and 63 deletions.
1 change: 1 addition & 0 deletions quickwit/quickwit-cli/src/index.rs
Original file line number Diff line number Diff line change
Expand Up @@ -993,6 +993,7 @@ pub async fn search_index(args: SearchIndexArgs) -> anyhow::Result<SearchRespons
sort_fields: vec![SortField {
field_name: "_score".to_string(),
sort_order: SortOrder::Desc as i32,
sort_datetime_format: None,
}],
})
.unwrap_or_default();
Expand Down
12 changes: 12 additions & 0 deletions quickwit/quickwit-proto/protos/quickwit/search.proto
Original file line number Diff line number Diff line change
Expand Up @@ -185,6 +185,10 @@ enum CountHits {
message SortField {
string field_name = 1;
SortOrder sort_order = 2;
// Optional sort value format for datetime field only.
// If none, the default output format for datetime field is
// unix_timestamp_nanos.
optional SortDatetimeFormat sort_datetime_format = 3;
}

enum SortOrder {
Expand All @@ -194,6 +198,14 @@ enum SortOrder {
DESC = 1; //< This will be the default value;
}

// Sort value format for datetime field.
// We keep an enum with only one format
// for future extension.
enum SortDatetimeFormat {
UNIX_TIMESTAMP_MILLIS = 0;
UNIX_TIMESTAMP_NANOS = 1;
}

message SearchResponse {
// Number of hits matching the query.
uint64 num_hits = 1;
Expand Down
36 changes: 36 additions & 0 deletions quickwit/quickwit-proto/src/codegen/quickwit/quickwit.search.rs

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

14 changes: 13 additions & 1 deletion quickwit/quickwit-proto/src/search/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -104,7 +104,19 @@ impl SortByValue {
return None;
}
}
String(_) | Array(_) | Object(_) => return None,
// Strings that can be converted to a number are accepted.
// Some clients (like JS clients) can't easily handle large integers
// without losing precision, so we accept them as strings.
String(value) => {
if let Ok(number) = value.parse::<u64>() {
Some(SortValue::U64(number))
} else if let Ok(number) = value.parse::<i64>() {
Some(SortValue::I64(number))
} else {
return None;
}
}
Array(_) | Object(_) => return None,
};
Some(SortByValue { sort_value })
}
Expand Down
8 changes: 8 additions & 0 deletions quickwit/quickwit-search/src/collector.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1308,11 +1308,13 @@ mod tests {
SortField {
field_name: field.to_string(),
sort_order: SortOrder::Asc.into(),
sort_datetime_format: None,
}
} else {
SortField {
field_name: field.to_string(),
sort_order: SortOrder::Desc.into(),
sort_datetime_format: None,
}
}
})
Expand Down Expand Up @@ -1538,10 +1540,12 @@ mod tests {
SortField {
field_name: "sort1".to_string(),
sort_order: SortOrder::Desc.into(),
sort_datetime_format: None,
},
SortField {
field_name: "sort2".to_string(),
sort_order: SortOrder::Asc.into(),
sort_datetime_format: None,
},
],
search_after: Some(search_after),
Expand Down Expand Up @@ -1580,6 +1584,7 @@ mod tests {
sort_fields: vec![SortField {
field_name: "_shard_doc".to_string(),
sort_order: SortOrder::Desc.into(),
sort_datetime_format: None,
}],
search_after: Some(search_after),
..SearchRequest::default()
Expand Down Expand Up @@ -1660,6 +1665,7 @@ mod tests {
sort_fields: vec![SortField {
field_name: "timestamp".to_string(),
sort_order: SortOrder::Desc as i32,
sort_datetime_format: None,
}],
aggregation_request: None,
..Default::default()
Expand Down Expand Up @@ -1703,6 +1709,7 @@ mod tests {
sort_fields: vec![SortField {
field_name: "timestamp".to_string(),
sort_order: SortOrder::Desc as i32,
sort_datetime_format: None,
}],
aggregation_request: None,
..Default::default()
Expand Down Expand Up @@ -1788,6 +1795,7 @@ mod tests {
sort_fields: vec![SortField {
field_name: "timestamp".to_string(),
sort_order: SortOrder::Asc as i32,
sort_datetime_format: None,
}],
aggregation_request: None,
..Default::default()
Expand Down
Loading

0 comments on commit 0a6e45e

Please sign in to comment.