2021-04-29 08:48:06 +00:00
|
|
|
syntax = "proto3";
|
|
|
|
package milvus.proto.plan;
|
|
|
|
|
|
|
|
option go_package = "github.com/milvus-io/milvus/internal/proto/planpb";
|
|
|
|
import "schema.proto";
|
|
|
|
|
2021-07-13 06:37:03 +00:00
|
|
|
enum OpType {
|
|
|
|
Invalid = 0;
|
|
|
|
GreaterThan = 1;
|
|
|
|
GreaterEqual = 2;
|
|
|
|
LessThan = 3;
|
|
|
|
LessEqual = 4;
|
|
|
|
Equal = 5;
|
|
|
|
NotEqual = 6;
|
2022-04-29 05:35:49 +00:00
|
|
|
PrefixMatch = 7; // startsWith
|
|
|
|
PostfixMatch = 8; // endsWith
|
2022-05-06 09:43:51 +00:00
|
|
|
Match = 9; // like
|
2022-05-24 13:56:00 +00:00
|
|
|
Range = 10; // for case 1 < a < b
|
|
|
|
In = 11; // TODO:: used for term expr
|
|
|
|
NotIn = 12;
|
2021-07-13 06:37:03 +00:00
|
|
|
};
|
|
|
|
|
2022-04-24 08:43:45 +00:00
|
|
|
enum ArithOpType {
|
|
|
|
Unknown = 0;
|
|
|
|
Add = 1;
|
|
|
|
Sub = 2;
|
|
|
|
Mul = 3;
|
|
|
|
Div = 4;
|
|
|
|
Mod = 5;
|
2023-09-19 06:23:23 +00:00
|
|
|
ArrayLength = 6;
|
2022-04-24 08:43:45 +00:00
|
|
|
};
|
|
|
|
|
2023-09-08 02:03:16 +00:00
|
|
|
enum VectorType {
|
|
|
|
BinaryVector = 0;
|
|
|
|
FloatVector = 1;
|
|
|
|
Float16Vector = 2;
|
2024-01-11 07:48:51 +00:00
|
|
|
BFloat16Vector = 3;
|
2024-03-12 16:16:30 +00:00
|
|
|
SparseFloatVector = 4;
|
2023-09-08 02:03:16 +00:00
|
|
|
};
|
|
|
|
|
2021-04-29 08:48:06 +00:00
|
|
|
message GenericValue {
|
|
|
|
oneof val {
|
|
|
|
bool bool_val = 1;
|
|
|
|
int64 int64_val = 2;
|
|
|
|
double float_val = 3;
|
2022-04-02 09:43:29 +00:00
|
|
|
string string_val = 4;
|
2023-08-11 09:09:30 +00:00
|
|
|
Array array_val = 5;
|
2021-04-29 08:48:06 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2023-08-11 09:09:30 +00:00
|
|
|
message Array {
|
|
|
|
repeated GenericValue array = 1;
|
|
|
|
bool same_type = 2;
|
2023-09-19 06:23:23 +00:00
|
|
|
schema.DataType element_type = 3;
|
2023-08-11 09:09:30 +00:00
|
|
|
}
|
|
|
|
|
2021-04-29 08:48:06 +00:00
|
|
|
message QueryInfo {
|
|
|
|
int64 topk = 1;
|
|
|
|
string metric_type = 3;
|
|
|
|
string search_params = 4;
|
2021-10-08 09:39:55 +00:00
|
|
|
int64 round_decimal = 5;
|
2024-01-05 07:50:47 +00:00
|
|
|
int64 group_by_field_id = 6;
|
2024-03-21 03:19:07 +00:00
|
|
|
bool materialized_view_involved = 7;
|
2021-04-29 08:48:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
message ColumnInfo {
|
|
|
|
int64 field_id = 1;
|
|
|
|
schema.DataType data_type = 2;
|
2021-06-07 09:21:36 +00:00
|
|
|
bool is_primary_key = 3;
|
|
|
|
bool is_autoID = 4;
|
2023-04-24 09:14:34 +00:00
|
|
|
repeated string nested_path = 5;
|
2023-06-06 02:24:34 +00:00
|
|
|
bool is_partition_key = 6;
|
2023-09-19 06:23:23 +00:00
|
|
|
schema.DataType element_type = 7;
|
2021-04-29 08:48:06 +00:00
|
|
|
}
|
|
|
|
|
2022-05-06 09:43:51 +00:00
|
|
|
message ColumnExpr {
|
|
|
|
ColumnInfo info = 1;
|
|
|
|
}
|
|
|
|
|
2023-05-10 02:19:19 +00:00
|
|
|
message ExistsExpr {
|
|
|
|
ColumnInfo info = 1;
|
|
|
|
}
|
|
|
|
|
2022-05-06 09:43:51 +00:00
|
|
|
message ValueExpr {
|
|
|
|
GenericValue value = 1;
|
|
|
|
}
|
|
|
|
|
2021-07-25 02:23:19 +00:00
|
|
|
message UnaryRangeExpr {
|
2021-04-29 08:48:06 +00:00
|
|
|
ColumnInfo column_info = 1;
|
2021-07-25 02:23:19 +00:00
|
|
|
OpType op = 2;
|
|
|
|
GenericValue value = 3;
|
|
|
|
}
|
|
|
|
|
|
|
|
message BinaryRangeExpr {
|
|
|
|
ColumnInfo column_info = 1;
|
|
|
|
bool lower_inclusive = 2;
|
|
|
|
bool upper_inclusive = 3;
|
|
|
|
GenericValue lower_value = 4;
|
|
|
|
GenericValue upper_value = 5;
|
2021-04-29 08:48:06 +00:00
|
|
|
}
|
|
|
|
|
2021-07-13 06:37:03 +00:00
|
|
|
message CompareExpr {
|
2021-07-25 02:23:19 +00:00
|
|
|
ColumnInfo left_column_info = 1;
|
|
|
|
ColumnInfo right_column_info = 2;
|
|
|
|
OpType op = 3;
|
2021-07-13 06:37:03 +00:00
|
|
|
}
|
|
|
|
|
2021-04-29 08:48:06 +00:00
|
|
|
message TermExpr {
|
|
|
|
ColumnInfo column_info = 1;
|
|
|
|
repeated GenericValue values = 2;
|
2023-06-07 09:24:36 +00:00
|
|
|
bool is_in_field = 3;
|
2021-04-29 08:48:06 +00:00
|
|
|
}
|
|
|
|
|
2023-08-11 09:09:30 +00:00
|
|
|
message JSONContainsExpr {
|
|
|
|
ColumnInfo column_info = 1;
|
|
|
|
repeated GenericValue elements = 2;
|
|
|
|
// 0: invalid
|
2023-09-19 06:23:23 +00:00
|
|
|
// 1: json_contains | array_contains
|
|
|
|
// 2: json_contains_all | array_contains_all
|
|
|
|
// 3: json_contains_any | array_contains_any
|
2023-08-11 09:09:30 +00:00
|
|
|
enum JSONOp {
|
|
|
|
Invalid = 0;
|
|
|
|
Contains = 1;
|
|
|
|
ContainsAll = 2;
|
|
|
|
ContainsAny = 3;
|
|
|
|
}
|
|
|
|
JSONOp op = 3;
|
|
|
|
bool elements_same_type = 4;
|
|
|
|
}
|
|
|
|
|
2021-04-29 08:48:06 +00:00
|
|
|
message UnaryExpr {
|
2021-07-13 06:37:03 +00:00
|
|
|
enum UnaryOp {
|
2021-04-29 08:48:06 +00:00
|
|
|
Invalid = 0;
|
|
|
|
Not = 1;
|
|
|
|
};
|
|
|
|
UnaryOp op = 1;
|
|
|
|
Expr child = 2;
|
|
|
|
}
|
|
|
|
|
|
|
|
message BinaryExpr {
|
|
|
|
enum BinaryOp {
|
|
|
|
Invalid = 0;
|
|
|
|
LogicalAnd = 1;
|
|
|
|
LogicalOr = 2;
|
|
|
|
}
|
2021-04-30 07:19:52 +00:00
|
|
|
BinaryOp op = 1;
|
|
|
|
Expr left = 2;
|
|
|
|
Expr right = 3;
|
2021-04-29 08:48:06 +00:00
|
|
|
}
|
|
|
|
|
2022-04-24 08:43:45 +00:00
|
|
|
message BinaryArithOp {
|
|
|
|
ColumnInfo column_info = 1;
|
|
|
|
ArithOpType arith_op = 2;
|
|
|
|
GenericValue right_operand = 3;
|
|
|
|
}
|
|
|
|
|
2022-05-06 09:43:51 +00:00
|
|
|
message BinaryArithExpr {
|
|
|
|
Expr left = 1;
|
|
|
|
Expr right = 2;
|
|
|
|
ArithOpType op = 3;
|
|
|
|
}
|
|
|
|
|
2022-04-24 08:43:45 +00:00
|
|
|
message BinaryArithOpEvalRangeExpr {
|
|
|
|
ColumnInfo column_info = 1;
|
|
|
|
ArithOpType arith_op = 2;
|
|
|
|
GenericValue right_operand = 3;
|
|
|
|
OpType op = 4;
|
|
|
|
GenericValue value = 5;
|
|
|
|
}
|
|
|
|
|
2023-08-10 00:37:15 +00:00
|
|
|
message AlwaysTrueExpr {}
|
|
|
|
|
2021-04-29 08:48:06 +00:00
|
|
|
message Expr {
|
|
|
|
oneof expr {
|
2021-07-25 02:23:19 +00:00
|
|
|
TermExpr term_expr = 1;
|
|
|
|
UnaryExpr unary_expr = 2;
|
|
|
|
BinaryExpr binary_expr = 3;
|
|
|
|
CompareExpr compare_expr = 4;
|
|
|
|
UnaryRangeExpr unary_range_expr = 5;
|
|
|
|
BinaryRangeExpr binary_range_expr = 6;
|
2022-04-24 08:43:45 +00:00
|
|
|
BinaryArithOpEvalRangeExpr binary_arith_op_eval_range_expr = 7;
|
2022-05-06 09:43:51 +00:00
|
|
|
BinaryArithExpr binary_arith_expr = 8;
|
|
|
|
ValueExpr value_expr = 9;
|
|
|
|
ColumnExpr column_expr = 10;
|
2023-05-10 02:19:19 +00:00
|
|
|
ExistsExpr exists_expr = 11;
|
2023-08-10 00:37:15 +00:00
|
|
|
AlwaysTrueExpr always_true_expr = 12;
|
2023-08-11 09:09:30 +00:00
|
|
|
JSONContainsExpr json_contains_expr = 13;
|
2021-04-29 08:48:06 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
message VectorANNS {
|
2023-09-08 02:03:16 +00:00
|
|
|
VectorType vector_type = 1;
|
2021-04-29 08:48:06 +00:00
|
|
|
int64 field_id = 2;
|
|
|
|
Expr predicates = 3;
|
|
|
|
QueryInfo query_info = 4;
|
|
|
|
string placeholder_tag = 5; // always be "$0"
|
|
|
|
}
|
|
|
|
|
2023-03-16 11:31:55 +00:00
|
|
|
message QueryPlanNode {
|
|
|
|
Expr predicates = 1;
|
|
|
|
bool is_count = 2;
|
2023-08-01 12:29:05 +00:00
|
|
|
int64 limit = 3;
|
2023-03-16 11:31:55 +00:00
|
|
|
};
|
|
|
|
|
2021-04-29 08:48:06 +00:00
|
|
|
message PlanNode {
|
|
|
|
oneof node {
|
|
|
|
VectorANNS vector_anns = 1;
|
2023-03-16 11:31:55 +00:00
|
|
|
Expr predicates = 2; // deprecated, use query instead.
|
|
|
|
QueryPlanNode query = 4;
|
2021-04-29 08:48:06 +00:00
|
|
|
}
|
2021-09-03 09:12:55 +00:00
|
|
|
repeated int64 output_field_ids = 3;
|
2021-06-04 02:38:34 +00:00
|
|
|
}
|