2020-10-24 10:04:57 +00:00
|
|
|
syntax = "proto3";
|
|
|
|
|
|
|
|
package milvus.proto.schema;
|
2021-05-19 10:45:15 +00:00
|
|
|
option go_package = "github.com/milvus-io/milvus/internal/proto/schemapb";
|
2020-10-24 10:04:57 +00:00
|
|
|
|
|
|
|
import "common.proto";
|
2020-10-23 10:01:24 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Field data type
|
|
|
|
*/
|
|
|
|
enum DataType {
|
2021-03-12 06:22:09 +00:00
|
|
|
None = 0;
|
|
|
|
Bool = 1;
|
|
|
|
Int8 = 2;
|
|
|
|
Int16 = 3;
|
|
|
|
Int32 = 4;
|
|
|
|
Int64 = 5;
|
2020-10-23 10:01:24 +00:00
|
|
|
|
2021-03-12 06:22:09 +00:00
|
|
|
Float = 10;
|
|
|
|
Double = 11;
|
2020-10-23 10:01:24 +00:00
|
|
|
|
2021-03-12 06:22:09 +00:00
|
|
|
String = 20;
|
2020-10-23 10:01:24 +00:00
|
|
|
|
2021-03-12 06:22:09 +00:00
|
|
|
BinaryVector = 100;
|
|
|
|
FloatVector = 101;
|
2020-10-23 10:01:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Field schema
|
|
|
|
*/
|
|
|
|
message FieldSchema {
|
2021-03-12 06:22:09 +00:00
|
|
|
int64 fieldID = 1;
|
|
|
|
string name = 2;
|
|
|
|
bool is_primary_key = 3;
|
|
|
|
string description = 4;
|
|
|
|
DataType data_type = 5;
|
|
|
|
repeated common.KeyValuePair type_params = 6;
|
|
|
|
repeated common.KeyValuePair index_params = 7;
|
2021-06-21 03:42:18 +00:00
|
|
|
bool autoID = 8;
|
2020-10-23 10:01:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Collection schema
|
|
|
|
*/
|
|
|
|
message CollectionSchema {
|
2021-03-12 06:22:09 +00:00
|
|
|
string name = 1;
|
|
|
|
string description = 2;
|
2021-06-21 03:42:18 +00:00
|
|
|
bool autoID = 3; // deprecated later, keep compatible with c++ part now
|
2021-03-12 06:22:09 +00:00
|
|
|
repeated FieldSchema fields = 4;
|
2020-10-28 02:09:35 +00:00
|
|
|
}
|
2021-05-19 10:45:15 +00:00
|
|
|
|
|
|
|
message BoolArray {
|
|
|
|
repeated bool data = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
message IntArray {
|
|
|
|
repeated int32 data = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
message LongArray {
|
|
|
|
repeated int64 data = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
message FloatArray {
|
|
|
|
repeated float data = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
message DoubleArray {
|
|
|
|
repeated double data = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
// For special fields such as bigdecimal, array...
|
|
|
|
message BytesArray {
|
|
|
|
repeated bytes data = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
message StringArray {
|
|
|
|
repeated string data = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
message ScalarField {
|
|
|
|
oneof data {
|
|
|
|
BoolArray bool_data = 1;
|
|
|
|
IntArray int_data = 2;
|
|
|
|
LongArray long_data = 3;
|
|
|
|
FloatArray float_data = 4;
|
|
|
|
DoubleArray double_data = 5;
|
|
|
|
StringArray string_data = 6;
|
|
|
|
BytesArray bytes_data = 7;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
message VectorField {
|
|
|
|
int64 dim = 1;
|
|
|
|
oneof data {
|
|
|
|
FloatArray float_vector = 2;
|
|
|
|
bytes binary_vector = 3;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
message FieldData {
|
|
|
|
DataType type = 1;
|
|
|
|
string field_name = 2;
|
|
|
|
oneof field {
|
|
|
|
ScalarField scalars = 3;
|
|
|
|
VectorField vectors = 4;
|
|
|
|
}
|
2021-07-16 09:19:55 +00:00
|
|
|
int64 field_id = 5;
|
2021-05-19 10:45:15 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
message IDs {
|
|
|
|
oneof id_field {
|
|
|
|
LongArray int_id = 1;
|
|
|
|
StringArray str_id = 2;
|
|
|
|
}
|
|
|
|
}
|
2021-06-21 12:18:13 +00:00
|
|
|
|
|
|
|
message SearchResultData {
|
|
|
|
int64 num_queries = 1;
|
|
|
|
int64 top_k = 2;
|
|
|
|
repeated FieldData fields_data = 3;
|
|
|
|
repeated float scores = 4;
|
|
|
|
IDs ids = 5;
|
2021-06-28 07:28:11 +00:00
|
|
|
repeated int64 topks = 6;
|
2021-06-21 12:18:13 +00:00
|
|
|
}
|