From b0d6b05405917d619d095e6b239d4c4a0d62deb9 Mon Sep 17 00:00:00 2001 From: tasty-gumi <1021989072@qq.com> Date: Wed, 10 Jul 2024 08:53:55 +0800 Subject: [PATCH] support datatype geo after reabse fix:rename datatype Signed-off-by: tasty-gumi <1021989072@qq.com> --- go-api/schemapb/schema.pb.go | 280 +++++++++++++++++++++++------------ proto/schema.proto | 4 + 2 files changed, 186 insertions(+), 98 deletions(-) diff --git a/go-api/schemapb/schema.pb.go b/go-api/schemapb/schema.pb.go index a6eb864..2ca20b5 100644 --- a/go-api/schemapb/schema.pb.go +++ b/go-api/schemapb/schema.pb.go @@ -39,6 +39,7 @@ const ( DataType_VarChar DataType = 21 // variable-length strings with a specified maximum length DataType_Array DataType = 22 DataType_JSON DataType = 23 + DataType_Geometry DataType = 24 DataType_BinaryVector DataType = 100 DataType_FloatVector DataType = 101 DataType_Float16Vector DataType = 102 @@ -61,6 +62,7 @@ var ( 21: "VarChar", 22: "Array", 23: "JSON", + 24: "Geometry", 100: "BinaryVector", 101: "FloatVector", 102: "Float16Vector", @@ -80,6 +82,7 @@ var ( "VarChar": 21, "Array": 22, "JSON": 23, + "Geometry": 24, "BinaryVector": 100, "FloatVector": 101, "Float16Vector": 102, @@ -1028,6 +1031,53 @@ func (x *JSONArray) GetData() [][]byte { return nil } +type GeometryArray struct { + state protoimpl.MessageState + sizeCache protoimpl.SizeCache + unknownFields protoimpl.UnknownFields + + Data [][]byte `protobuf:"bytes,1,rep,name=data,proto3" json:"data,omitempty"` +} + +func (x *GeometryArray) Reset() { + *x = GeometryArray{} + if protoimpl.UnsafeEnabled { + mi := &file_schema_proto_msgTypes[12] + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + ms.StoreMessageInfo(mi) + } +} + +func (x *GeometryArray) String() string { + return protoimpl.X.MessageStringOf(x) +} + +func (*GeometryArray) ProtoMessage() {} + +func (x *GeometryArray) ProtoReflect() protoreflect.Message { + mi := &file_schema_proto_msgTypes[12] + if protoimpl.UnsafeEnabled && x != nil { + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + if ms.LoadMessageInfo() == nil { + ms.StoreMessageInfo(mi) + } + return ms + } + return mi.MessageOf(x) +} + +// Deprecated: Use GeometryArray.ProtoReflect.Descriptor instead. +func (*GeometryArray) Descriptor() ([]byte, []int) { + return file_schema_proto_rawDescGZIP(), []int{12} +} + +func (x *GeometryArray) GetData() [][]byte { + if x != nil { + return x.Data + } + return nil +} + type ValueField struct { state protoimpl.MessageState sizeCache protoimpl.SizeCache @@ -1048,7 +1098,7 @@ type ValueField struct { func (x *ValueField) Reset() { *x = ValueField{} if protoimpl.UnsafeEnabled { - mi := &file_schema_proto_msgTypes[12] + mi := &file_schema_proto_msgTypes[13] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -1061,7 +1111,7 @@ func (x *ValueField) String() string { func (*ValueField) ProtoMessage() {} func (x *ValueField) ProtoReflect() protoreflect.Message { - mi := &file_schema_proto_msgTypes[12] + mi := &file_schema_proto_msgTypes[13] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -1074,7 +1124,7 @@ func (x *ValueField) ProtoReflect() protoreflect.Message { // Deprecated: Use ValueField.ProtoReflect.Descriptor instead. func (*ValueField) Descriptor() ([]byte, []int) { - return file_schema_proto_rawDescGZIP(), []int{12} + return file_schema_proto_rawDescGZIP(), []int{13} } func (m *ValueField) GetData() isValueField_Data { @@ -1195,13 +1245,14 @@ type ScalarField struct { // *ScalarField_BytesData // *ScalarField_ArrayData // *ScalarField_JsonData + // *ScalarField_GeometryData Data isScalarField_Data `protobuf_oneof:"data"` } func (x *ScalarField) Reset() { *x = ScalarField{} if protoimpl.UnsafeEnabled { - mi := &file_schema_proto_msgTypes[13] + mi := &file_schema_proto_msgTypes[14] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -1214,7 +1265,7 @@ func (x *ScalarField) String() string { func (*ScalarField) ProtoMessage() {} func (x *ScalarField) ProtoReflect() protoreflect.Message { - mi := &file_schema_proto_msgTypes[13] + mi := &file_schema_proto_msgTypes[14] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -1227,7 +1278,7 @@ func (x *ScalarField) ProtoReflect() protoreflect.Message { // Deprecated: Use ScalarField.ProtoReflect.Descriptor instead. func (*ScalarField) Descriptor() ([]byte, []int) { - return file_schema_proto_rawDescGZIP(), []int{13} + return file_schema_proto_rawDescGZIP(), []int{14} } func (m *ScalarField) GetData() isScalarField_Data { @@ -1300,6 +1351,13 @@ func (x *ScalarField) GetJsonData() *JSONArray { return nil } +func (x *ScalarField) GetGeometryData() *GeometryArray { + if x, ok := x.GetData().(*ScalarField_GeometryData); ok { + return x.GeometryData + } + return nil +} + type isScalarField_Data interface { isScalarField_Data() } @@ -1340,6 +1398,10 @@ type ScalarField_JsonData struct { JsonData *JSONArray `protobuf:"bytes,9,opt,name=json_data,json=jsonData,proto3,oneof"` } +type ScalarField_GeometryData struct { + GeometryData *GeometryArray `protobuf:"bytes,10,opt,name=geometry_data,json=geometryData,proto3,oneof"` +} + func (*ScalarField_BoolData) isScalarField_Data() {} func (*ScalarField_IntData) isScalarField_Data() {} @@ -1358,6 +1420,8 @@ func (*ScalarField_ArrayData) isScalarField_Data() {} func (*ScalarField_JsonData) isScalarField_Data() {} +func (*ScalarField_GeometryData) isScalarField_Data() {} + // beta, api may change type SparseFloatArray struct { state protoimpl.MessageState @@ -1372,7 +1436,7 @@ type SparseFloatArray struct { func (x *SparseFloatArray) Reset() { *x = SparseFloatArray{} if protoimpl.UnsafeEnabled { - mi := &file_schema_proto_msgTypes[14] + mi := &file_schema_proto_msgTypes[15] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -1385,7 +1449,7 @@ func (x *SparseFloatArray) String() string { func (*SparseFloatArray) ProtoMessage() {} func (x *SparseFloatArray) ProtoReflect() protoreflect.Message { - mi := &file_schema_proto_msgTypes[14] + mi := &file_schema_proto_msgTypes[15] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -1398,7 +1462,7 @@ func (x *SparseFloatArray) ProtoReflect() protoreflect.Message { // Deprecated: Use SparseFloatArray.ProtoReflect.Descriptor instead. func (*SparseFloatArray) Descriptor() ([]byte, []int) { - return file_schema_proto_rawDescGZIP(), []int{14} + return file_schema_proto_rawDescGZIP(), []int{15} } func (x *SparseFloatArray) GetContents() [][]byte { @@ -1435,7 +1499,7 @@ type VectorField struct { func (x *VectorField) Reset() { *x = VectorField{} if protoimpl.UnsafeEnabled { - mi := &file_schema_proto_msgTypes[15] + mi := &file_schema_proto_msgTypes[16] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -1448,7 +1512,7 @@ func (x *VectorField) String() string { func (*VectorField) ProtoMessage() {} func (x *VectorField) ProtoReflect() protoreflect.Message { - mi := &file_schema_proto_msgTypes[15] + mi := &file_schema_proto_msgTypes[16] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -1461,7 +1525,7 @@ func (x *VectorField) ProtoReflect() protoreflect.Message { // Deprecated: Use VectorField.ProtoReflect.Descriptor instead. func (*VectorField) Descriptor() ([]byte, []int) { - return file_schema_proto_rawDescGZIP(), []int{15} + return file_schema_proto_rawDescGZIP(), []int{16} } func (x *VectorField) GetDim() int64 { @@ -1567,7 +1631,7 @@ type FieldData struct { func (x *FieldData) Reset() { *x = FieldData{} if protoimpl.UnsafeEnabled { - mi := &file_schema_proto_msgTypes[16] + mi := &file_schema_proto_msgTypes[17] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -1580,7 +1644,7 @@ func (x *FieldData) String() string { func (*FieldData) ProtoMessage() {} func (x *FieldData) ProtoReflect() protoreflect.Message { - mi := &file_schema_proto_msgTypes[16] + mi := &file_schema_proto_msgTypes[17] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -1593,7 +1657,7 @@ func (x *FieldData) ProtoReflect() protoreflect.Message { // Deprecated: Use FieldData.ProtoReflect.Descriptor instead. func (*FieldData) Descriptor() ([]byte, []int) { - return file_schema_proto_rawDescGZIP(), []int{16} + return file_schema_proto_rawDescGZIP(), []int{17} } func (x *FieldData) GetType() DataType { @@ -1683,7 +1747,7 @@ type IDs struct { func (x *IDs) Reset() { *x = IDs{} if protoimpl.UnsafeEnabled { - mi := &file_schema_proto_msgTypes[17] + mi := &file_schema_proto_msgTypes[18] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -1696,7 +1760,7 @@ func (x *IDs) String() string { func (*IDs) ProtoMessage() {} func (x *IDs) ProtoReflect() protoreflect.Message { - mi := &file_schema_proto_msgTypes[17] + mi := &file_schema_proto_msgTypes[18] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -1709,7 +1773,7 @@ func (x *IDs) ProtoReflect() protoreflect.Message { // Deprecated: Use IDs.ProtoReflect.Descriptor instead. func (*IDs) Descriptor() ([]byte, []int) { - return file_schema_proto_rawDescGZIP(), []int{17} + return file_schema_proto_rawDescGZIP(), []int{18} } func (m *IDs) GetIdField() isIDs_IdField { @@ -1769,7 +1833,7 @@ type SearchResultData struct { func (x *SearchResultData) Reset() { *x = SearchResultData{} if protoimpl.UnsafeEnabled { - mi := &file_schema_proto_msgTypes[18] + mi := &file_schema_proto_msgTypes[19] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -1782,7 +1846,7 @@ func (x *SearchResultData) String() string { func (*SearchResultData) ProtoMessage() {} func (x *SearchResultData) ProtoReflect() protoreflect.Message { - mi := &file_schema_proto_msgTypes[18] + mi := &file_schema_proto_msgTypes[19] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -1795,7 +1859,7 @@ func (x *SearchResultData) ProtoReflect() protoreflect.Message { // Deprecated: Use SearchResultData.ProtoReflect.Descriptor instead. func (*SearchResultData) Descriptor() ([]byte, []int) { - return file_schema_proto_rawDescGZIP(), []int{18} + return file_schema_proto_rawDescGZIP(), []int{19} } func (x *SearchResultData) GetNumQueries() int64 { @@ -1882,7 +1946,7 @@ type VectorClusteringInfo struct { func (x *VectorClusteringInfo) Reset() { *x = VectorClusteringInfo{} if protoimpl.UnsafeEnabled { - mi := &file_schema_proto_msgTypes[19] + mi := &file_schema_proto_msgTypes[20] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -1895,7 +1959,7 @@ func (x *VectorClusteringInfo) String() string { func (*VectorClusteringInfo) ProtoMessage() {} func (x *VectorClusteringInfo) ProtoReflect() protoreflect.Message { - mi := &file_schema_proto_msgTypes[19] + mi := &file_schema_proto_msgTypes[20] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -1908,7 +1972,7 @@ func (x *VectorClusteringInfo) ProtoReflect() protoreflect.Message { // Deprecated: Use VectorClusteringInfo.ProtoReflect.Descriptor instead. func (*VectorClusteringInfo) Descriptor() ([]byte, []int) { - return file_schema_proto_rawDescGZIP(), []int{19} + return file_schema_proto_rawDescGZIP(), []int{20} } func (x *VectorClusteringInfo) GetField() string { @@ -1938,7 +2002,7 @@ type ScalarClusteringInfo struct { func (x *ScalarClusteringInfo) Reset() { *x = ScalarClusteringInfo{} if protoimpl.UnsafeEnabled { - mi := &file_schema_proto_msgTypes[20] + mi := &file_schema_proto_msgTypes[21] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -1951,7 +2015,7 @@ func (x *ScalarClusteringInfo) String() string { func (*ScalarClusteringInfo) ProtoMessage() {} func (x *ScalarClusteringInfo) ProtoReflect() protoreflect.Message { - mi := &file_schema_proto_msgTypes[20] + mi := &file_schema_proto_msgTypes[21] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -1964,7 +2028,7 @@ func (x *ScalarClusteringInfo) ProtoReflect() protoreflect.Message { // Deprecated: Use ScalarClusteringInfo.ProtoReflect.Descriptor instead. func (*ScalarClusteringInfo) Descriptor() ([]byte, []int) { - return file_schema_proto_rawDescGZIP(), []int{20} + return file_schema_proto_rawDescGZIP(), []int{21} } func (x *ScalarClusteringInfo) GetField() string { @@ -1987,7 +2051,7 @@ type ClusteringInfo struct { func (x *ClusteringInfo) Reset() { *x = ClusteringInfo{} if protoimpl.UnsafeEnabled { - mi := &file_schema_proto_msgTypes[21] + mi := &file_schema_proto_msgTypes[22] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -2000,7 +2064,7 @@ func (x *ClusteringInfo) String() string { func (*ClusteringInfo) ProtoMessage() {} func (x *ClusteringInfo) ProtoReflect() protoreflect.Message { - mi := &file_schema_proto_msgTypes[21] + mi := &file_schema_proto_msgTypes[22] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -2013,7 +2077,7 @@ func (x *ClusteringInfo) ProtoReflect() protoreflect.Message { // Deprecated: Use ClusteringInfo.ProtoReflect.Descriptor instead. func (*ClusteringInfo) Descriptor() ([]byte, []int) { - return file_schema_proto_rawDescGZIP(), []int{21} + return file_schema_proto_rawDescGZIP(), []int{22} } func (x *ClusteringInfo) GetVectorClusteringInfos() []*VectorClusteringInfo { @@ -2348,60 +2412,67 @@ var file_schema_proto_rawDesc = []byte{ 0x6d, 0x61, 0x2e, 0x44, 0x61, 0x74, 0x61, 0x54, 0x79, 0x70, 0x65, 0x52, 0x0b, 0x65, 0x6c, 0x65, 0x6d, 0x65, 0x6e, 0x74, 0x54, 0x79, 0x70, 0x65, 0x22, 0x1f, 0x0a, 0x09, 0x4a, 0x53, 0x4f, 0x4e, 0x41, 0x72, 0x72, 0x61, 0x79, 0x12, 0x12, 0x0a, 0x04, 0x64, 0x61, 0x74, 0x61, 0x18, 0x01, 0x20, - 0x03, 0x28, 0x0c, 0x52, 0x04, 0x64, 0x61, 0x74, 0x61, 0x22, 0xf7, 0x01, 0x0a, 0x0a, 0x56, 0x61, - 0x6c, 0x75, 0x65, 0x46, 0x69, 0x65, 0x6c, 0x64, 0x12, 0x1d, 0x0a, 0x09, 0x62, 0x6f, 0x6f, 0x6c, - 0x5f, 0x64, 0x61, 0x74, 0x61, 0x18, 0x01, 0x20, 0x01, 0x28, 0x08, 0x48, 0x00, 0x52, 0x08, 0x62, - 0x6f, 0x6f, 0x6c, 0x44, 0x61, 0x74, 0x61, 0x12, 0x1b, 0x0a, 0x08, 0x69, 0x6e, 0x74, 0x5f, 0x64, - 0x61, 0x74, 0x61, 0x18, 0x02, 0x20, 0x01, 0x28, 0x05, 0x48, 0x00, 0x52, 0x07, 0x69, 0x6e, 0x74, - 0x44, 0x61, 0x74, 0x61, 0x12, 0x1d, 0x0a, 0x09, 0x6c, 0x6f, 0x6e, 0x67, 0x5f, 0x64, 0x61, 0x74, - 0x61, 0x18, 0x03, 0x20, 0x01, 0x28, 0x03, 0x48, 0x00, 0x52, 0x08, 0x6c, 0x6f, 0x6e, 0x67, 0x44, - 0x61, 0x74, 0x61, 0x12, 0x1f, 0x0a, 0x0a, 0x66, 0x6c, 0x6f, 0x61, 0x74, 0x5f, 0x64, 0x61, 0x74, - 0x61, 0x18, 0x04, 0x20, 0x01, 0x28, 0x02, 0x48, 0x00, 0x52, 0x09, 0x66, 0x6c, 0x6f, 0x61, 0x74, - 0x44, 0x61, 0x74, 0x61, 0x12, 0x21, 0x0a, 0x0b, 0x64, 0x6f, 0x75, 0x62, 0x6c, 0x65, 0x5f, 0x64, - 0x61, 0x74, 0x61, 0x18, 0x05, 0x20, 0x01, 0x28, 0x01, 0x48, 0x00, 0x52, 0x0a, 0x64, 0x6f, 0x75, - 0x62, 0x6c, 0x65, 0x44, 0x61, 0x74, 0x61, 0x12, 0x21, 0x0a, 0x0b, 0x73, 0x74, 0x72, 0x69, 0x6e, - 0x67, 0x5f, 0x64, 0x61, 0x74, 0x61, 0x18, 0x06, 0x20, 0x01, 0x28, 0x09, 0x48, 0x00, 0x52, 0x0a, - 0x73, 0x74, 0x72, 0x69, 0x6e, 0x67, 0x44, 0x61, 0x74, 0x61, 0x12, 0x1f, 0x0a, 0x0a, 0x62, 0x79, - 0x74, 0x65, 0x73, 0x5f, 0x64, 0x61, 0x74, 0x61, 0x18, 0x07, 0x20, 0x01, 0x28, 0x0c, 0x48, 0x00, - 0x52, 0x09, 0x62, 0x79, 0x74, 0x65, 0x73, 0x44, 0x61, 0x74, 0x61, 0x42, 0x06, 0x0a, 0x04, 0x64, - 0x61, 0x74, 0x61, 0x22, 0xde, 0x04, 0x0a, 0x0b, 0x53, 0x63, 0x61, 0x6c, 0x61, 0x72, 0x46, 0x69, - 0x65, 0x6c, 0x64, 0x12, 0x3d, 0x0a, 0x09, 0x62, 0x6f, 0x6f, 0x6c, 0x5f, 0x64, 0x61, 0x74, 0x61, - 0x18, 0x01, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x1e, 0x2e, 0x6d, 0x69, 0x6c, 0x76, 0x75, 0x73, 0x2e, - 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x73, 0x63, 0x68, 0x65, 0x6d, 0x61, 0x2e, 0x42, 0x6f, 0x6f, - 0x6c, 0x41, 0x72, 0x72, 0x61, 0x79, 0x48, 0x00, 0x52, 0x08, 0x62, 0x6f, 0x6f, 0x6c, 0x44, 0x61, - 0x74, 0x61, 0x12, 0x3a, 0x0a, 0x08, 0x69, 0x6e, 0x74, 0x5f, 0x64, 0x61, 0x74, 0x61, 0x18, 0x02, - 0x20, 0x01, 0x28, 0x0b, 0x32, 0x1d, 0x2e, 0x6d, 0x69, 0x6c, 0x76, 0x75, 0x73, 0x2e, 0x70, 0x72, - 0x6f, 0x74, 0x6f, 0x2e, 0x73, 0x63, 0x68, 0x65, 0x6d, 0x61, 0x2e, 0x49, 0x6e, 0x74, 0x41, 0x72, - 0x72, 0x61, 0x79, 0x48, 0x00, 0x52, 0x07, 0x69, 0x6e, 0x74, 0x44, 0x61, 0x74, 0x61, 0x12, 0x3d, - 0x0a, 0x09, 0x6c, 0x6f, 0x6e, 0x67, 0x5f, 0x64, 0x61, 0x74, 0x61, 0x18, 0x03, 0x20, 0x01, 0x28, - 0x0b, 0x32, 0x1e, 0x2e, 0x6d, 0x69, 0x6c, 0x76, 0x75, 0x73, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, - 0x2e, 0x73, 0x63, 0x68, 0x65, 0x6d, 0x61, 0x2e, 0x4c, 0x6f, 0x6e, 0x67, 0x41, 0x72, 0x72, 0x61, - 0x79, 0x48, 0x00, 0x52, 0x08, 0x6c, 0x6f, 0x6e, 0x67, 0x44, 0x61, 0x74, 0x61, 0x12, 0x40, 0x0a, - 0x0a, 0x66, 0x6c, 0x6f, 0x61, 0x74, 0x5f, 0x64, 0x61, 0x74, 0x61, 0x18, 0x04, 0x20, 0x01, 0x28, - 0x0b, 0x32, 0x1f, 0x2e, 0x6d, 0x69, 0x6c, 0x76, 0x75, 0x73, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, - 0x2e, 0x73, 0x63, 0x68, 0x65, 0x6d, 0x61, 0x2e, 0x46, 0x6c, 0x6f, 0x61, 0x74, 0x41, 0x72, 0x72, - 0x61, 0x79, 0x48, 0x00, 0x52, 0x09, 0x66, 0x6c, 0x6f, 0x61, 0x74, 0x44, 0x61, 0x74, 0x61, 0x12, - 0x43, 0x0a, 0x0b, 0x64, 0x6f, 0x75, 0x62, 0x6c, 0x65, 0x5f, 0x64, 0x61, 0x74, 0x61, 0x18, 0x05, - 0x20, 0x01, 0x28, 0x0b, 0x32, 0x20, 0x2e, 0x6d, 0x69, 0x6c, 0x76, 0x75, 0x73, 0x2e, 0x70, 0x72, - 0x6f, 0x74, 0x6f, 0x2e, 0x73, 0x63, 0x68, 0x65, 0x6d, 0x61, 0x2e, 0x44, 0x6f, 0x75, 0x62, 0x6c, - 0x65, 0x41, 0x72, 0x72, 0x61, 0x79, 0x48, 0x00, 0x52, 0x0a, 0x64, 0x6f, 0x75, 0x62, 0x6c, 0x65, - 0x44, 0x61, 0x74, 0x61, 0x12, 0x43, 0x0a, 0x0b, 0x73, 0x74, 0x72, 0x69, 0x6e, 0x67, 0x5f, 0x64, - 0x61, 0x74, 0x61, 0x18, 0x06, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x20, 0x2e, 0x6d, 0x69, 0x6c, 0x76, + 0x03, 0x28, 0x0c, 0x52, 0x04, 0x64, 0x61, 0x74, 0x61, 0x22, 0x23, 0x0a, 0x0d, 0x47, 0x65, 0x6f, + 0x6d, 0x65, 0x74, 0x72, 0x79, 0x41, 0x72, 0x72, 0x61, 0x79, 0x12, 0x12, 0x0a, 0x04, 0x64, 0x61, + 0x74, 0x61, 0x18, 0x01, 0x20, 0x03, 0x28, 0x0c, 0x52, 0x04, 0x64, 0x61, 0x74, 0x61, 0x22, 0xf7, + 0x01, 0x0a, 0x0a, 0x56, 0x61, 0x6c, 0x75, 0x65, 0x46, 0x69, 0x65, 0x6c, 0x64, 0x12, 0x1d, 0x0a, + 0x09, 0x62, 0x6f, 0x6f, 0x6c, 0x5f, 0x64, 0x61, 0x74, 0x61, 0x18, 0x01, 0x20, 0x01, 0x28, 0x08, + 0x48, 0x00, 0x52, 0x08, 0x62, 0x6f, 0x6f, 0x6c, 0x44, 0x61, 0x74, 0x61, 0x12, 0x1b, 0x0a, 0x08, + 0x69, 0x6e, 0x74, 0x5f, 0x64, 0x61, 0x74, 0x61, 0x18, 0x02, 0x20, 0x01, 0x28, 0x05, 0x48, 0x00, + 0x52, 0x07, 0x69, 0x6e, 0x74, 0x44, 0x61, 0x74, 0x61, 0x12, 0x1d, 0x0a, 0x09, 0x6c, 0x6f, 0x6e, + 0x67, 0x5f, 0x64, 0x61, 0x74, 0x61, 0x18, 0x03, 0x20, 0x01, 0x28, 0x03, 0x48, 0x00, 0x52, 0x08, + 0x6c, 0x6f, 0x6e, 0x67, 0x44, 0x61, 0x74, 0x61, 0x12, 0x1f, 0x0a, 0x0a, 0x66, 0x6c, 0x6f, 0x61, + 0x74, 0x5f, 0x64, 0x61, 0x74, 0x61, 0x18, 0x04, 0x20, 0x01, 0x28, 0x02, 0x48, 0x00, 0x52, 0x09, + 0x66, 0x6c, 0x6f, 0x61, 0x74, 0x44, 0x61, 0x74, 0x61, 0x12, 0x21, 0x0a, 0x0b, 0x64, 0x6f, 0x75, + 0x62, 0x6c, 0x65, 0x5f, 0x64, 0x61, 0x74, 0x61, 0x18, 0x05, 0x20, 0x01, 0x28, 0x01, 0x48, 0x00, + 0x52, 0x0a, 0x64, 0x6f, 0x75, 0x62, 0x6c, 0x65, 0x44, 0x61, 0x74, 0x61, 0x12, 0x21, 0x0a, 0x0b, + 0x73, 0x74, 0x72, 0x69, 0x6e, 0x67, 0x5f, 0x64, 0x61, 0x74, 0x61, 0x18, 0x06, 0x20, 0x01, 0x28, + 0x09, 0x48, 0x00, 0x52, 0x0a, 0x73, 0x74, 0x72, 0x69, 0x6e, 0x67, 0x44, 0x61, 0x74, 0x61, 0x12, + 0x1f, 0x0a, 0x0a, 0x62, 0x79, 0x74, 0x65, 0x73, 0x5f, 0x64, 0x61, 0x74, 0x61, 0x18, 0x07, 0x20, + 0x01, 0x28, 0x0c, 0x48, 0x00, 0x52, 0x09, 0x62, 0x79, 0x74, 0x65, 0x73, 0x44, 0x61, 0x74, 0x61, + 0x42, 0x06, 0x0a, 0x04, 0x64, 0x61, 0x74, 0x61, 0x22, 0xa9, 0x05, 0x0a, 0x0b, 0x53, 0x63, 0x61, + 0x6c, 0x61, 0x72, 0x46, 0x69, 0x65, 0x6c, 0x64, 0x12, 0x3d, 0x0a, 0x09, 0x62, 0x6f, 0x6f, 0x6c, + 0x5f, 0x64, 0x61, 0x74, 0x61, 0x18, 0x01, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x1e, 0x2e, 0x6d, 0x69, + 0x6c, 0x76, 0x75, 0x73, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x73, 0x63, 0x68, 0x65, 0x6d, + 0x61, 0x2e, 0x42, 0x6f, 0x6f, 0x6c, 0x41, 0x72, 0x72, 0x61, 0x79, 0x48, 0x00, 0x52, 0x08, 0x62, + 0x6f, 0x6f, 0x6c, 0x44, 0x61, 0x74, 0x61, 0x12, 0x3a, 0x0a, 0x08, 0x69, 0x6e, 0x74, 0x5f, 0x64, + 0x61, 0x74, 0x61, 0x18, 0x02, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x1d, 0x2e, 0x6d, 0x69, 0x6c, 0x76, 0x75, 0x73, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x73, 0x63, 0x68, 0x65, 0x6d, 0x61, 0x2e, - 0x53, 0x74, 0x72, 0x69, 0x6e, 0x67, 0x41, 0x72, 0x72, 0x61, 0x79, 0x48, 0x00, 0x52, 0x0a, 0x73, - 0x74, 0x72, 0x69, 0x6e, 0x67, 0x44, 0x61, 0x74, 0x61, 0x12, 0x40, 0x0a, 0x0a, 0x62, 0x79, 0x74, - 0x65, 0x73, 0x5f, 0x64, 0x61, 0x74, 0x61, 0x18, 0x07, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x1f, 0x2e, - 0x6d, 0x69, 0x6c, 0x76, 0x75, 0x73, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x73, 0x63, 0x68, - 0x65, 0x6d, 0x61, 0x2e, 0x42, 0x79, 0x74, 0x65, 0x73, 0x41, 0x72, 0x72, 0x61, 0x79, 0x48, 0x00, - 0x52, 0x09, 0x62, 0x79, 0x74, 0x65, 0x73, 0x44, 0x61, 0x74, 0x61, 0x12, 0x40, 0x0a, 0x0a, 0x61, - 0x72, 0x72, 0x61, 0x79, 0x5f, 0x64, 0x61, 0x74, 0x61, 0x18, 0x08, 0x20, 0x01, 0x28, 0x0b, 0x32, - 0x1f, 0x2e, 0x6d, 0x69, 0x6c, 0x76, 0x75, 0x73, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x73, - 0x63, 0x68, 0x65, 0x6d, 0x61, 0x2e, 0x41, 0x72, 0x72, 0x61, 0x79, 0x41, 0x72, 0x72, 0x61, 0x79, - 0x48, 0x00, 0x52, 0x09, 0x61, 0x72, 0x72, 0x61, 0x79, 0x44, 0x61, 0x74, 0x61, 0x12, 0x3d, 0x0a, - 0x09, 0x6a, 0x73, 0x6f, 0x6e, 0x5f, 0x64, 0x61, 0x74, 0x61, 0x18, 0x09, 0x20, 0x01, 0x28, 0x0b, - 0x32, 0x1e, 0x2e, 0x6d, 0x69, 0x6c, 0x76, 0x75, 0x73, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, - 0x73, 0x63, 0x68, 0x65, 0x6d, 0x61, 0x2e, 0x4a, 0x53, 0x4f, 0x4e, 0x41, 0x72, 0x72, 0x61, 0x79, - 0x48, 0x00, 0x52, 0x08, 0x6a, 0x73, 0x6f, 0x6e, 0x44, 0x61, 0x74, 0x61, 0x42, 0x06, 0x0a, 0x04, + 0x49, 0x6e, 0x74, 0x41, 0x72, 0x72, 0x61, 0x79, 0x48, 0x00, 0x52, 0x07, 0x69, 0x6e, 0x74, 0x44, + 0x61, 0x74, 0x61, 0x12, 0x3d, 0x0a, 0x09, 0x6c, 0x6f, 0x6e, 0x67, 0x5f, 0x64, 0x61, 0x74, 0x61, + 0x18, 0x03, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x1e, 0x2e, 0x6d, 0x69, 0x6c, 0x76, 0x75, 0x73, 0x2e, + 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x73, 0x63, 0x68, 0x65, 0x6d, 0x61, 0x2e, 0x4c, 0x6f, 0x6e, + 0x67, 0x41, 0x72, 0x72, 0x61, 0x79, 0x48, 0x00, 0x52, 0x08, 0x6c, 0x6f, 0x6e, 0x67, 0x44, 0x61, + 0x74, 0x61, 0x12, 0x40, 0x0a, 0x0a, 0x66, 0x6c, 0x6f, 0x61, 0x74, 0x5f, 0x64, 0x61, 0x74, 0x61, + 0x18, 0x04, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x1f, 0x2e, 0x6d, 0x69, 0x6c, 0x76, 0x75, 0x73, 0x2e, + 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x73, 0x63, 0x68, 0x65, 0x6d, 0x61, 0x2e, 0x46, 0x6c, 0x6f, + 0x61, 0x74, 0x41, 0x72, 0x72, 0x61, 0x79, 0x48, 0x00, 0x52, 0x09, 0x66, 0x6c, 0x6f, 0x61, 0x74, + 0x44, 0x61, 0x74, 0x61, 0x12, 0x43, 0x0a, 0x0b, 0x64, 0x6f, 0x75, 0x62, 0x6c, 0x65, 0x5f, 0x64, + 0x61, 0x74, 0x61, 0x18, 0x05, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x20, 0x2e, 0x6d, 0x69, 0x6c, 0x76, + 0x75, 0x73, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x73, 0x63, 0x68, 0x65, 0x6d, 0x61, 0x2e, + 0x44, 0x6f, 0x75, 0x62, 0x6c, 0x65, 0x41, 0x72, 0x72, 0x61, 0x79, 0x48, 0x00, 0x52, 0x0a, 0x64, + 0x6f, 0x75, 0x62, 0x6c, 0x65, 0x44, 0x61, 0x74, 0x61, 0x12, 0x43, 0x0a, 0x0b, 0x73, 0x74, 0x72, + 0x69, 0x6e, 0x67, 0x5f, 0x64, 0x61, 0x74, 0x61, 0x18, 0x06, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x20, + 0x2e, 0x6d, 0x69, 0x6c, 0x76, 0x75, 0x73, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x73, 0x63, + 0x68, 0x65, 0x6d, 0x61, 0x2e, 0x53, 0x74, 0x72, 0x69, 0x6e, 0x67, 0x41, 0x72, 0x72, 0x61, 0x79, + 0x48, 0x00, 0x52, 0x0a, 0x73, 0x74, 0x72, 0x69, 0x6e, 0x67, 0x44, 0x61, 0x74, 0x61, 0x12, 0x40, + 0x0a, 0x0a, 0x62, 0x79, 0x74, 0x65, 0x73, 0x5f, 0x64, 0x61, 0x74, 0x61, 0x18, 0x07, 0x20, 0x01, + 0x28, 0x0b, 0x32, 0x1f, 0x2e, 0x6d, 0x69, 0x6c, 0x76, 0x75, 0x73, 0x2e, 0x70, 0x72, 0x6f, 0x74, + 0x6f, 0x2e, 0x73, 0x63, 0x68, 0x65, 0x6d, 0x61, 0x2e, 0x42, 0x79, 0x74, 0x65, 0x73, 0x41, 0x72, + 0x72, 0x61, 0x79, 0x48, 0x00, 0x52, 0x09, 0x62, 0x79, 0x74, 0x65, 0x73, 0x44, 0x61, 0x74, 0x61, + 0x12, 0x40, 0x0a, 0x0a, 0x61, 0x72, 0x72, 0x61, 0x79, 0x5f, 0x64, 0x61, 0x74, 0x61, 0x18, 0x08, + 0x20, 0x01, 0x28, 0x0b, 0x32, 0x1f, 0x2e, 0x6d, 0x69, 0x6c, 0x76, 0x75, 0x73, 0x2e, 0x70, 0x72, + 0x6f, 0x74, 0x6f, 0x2e, 0x73, 0x63, 0x68, 0x65, 0x6d, 0x61, 0x2e, 0x41, 0x72, 0x72, 0x61, 0x79, + 0x41, 0x72, 0x72, 0x61, 0x79, 0x48, 0x00, 0x52, 0x09, 0x61, 0x72, 0x72, 0x61, 0x79, 0x44, 0x61, + 0x74, 0x61, 0x12, 0x3d, 0x0a, 0x09, 0x6a, 0x73, 0x6f, 0x6e, 0x5f, 0x64, 0x61, 0x74, 0x61, 0x18, + 0x09, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x1e, 0x2e, 0x6d, 0x69, 0x6c, 0x76, 0x75, 0x73, 0x2e, 0x70, + 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x73, 0x63, 0x68, 0x65, 0x6d, 0x61, 0x2e, 0x4a, 0x53, 0x4f, 0x4e, + 0x41, 0x72, 0x72, 0x61, 0x79, 0x48, 0x00, 0x52, 0x08, 0x6a, 0x73, 0x6f, 0x6e, 0x44, 0x61, 0x74, + 0x61, 0x12, 0x49, 0x0a, 0x0d, 0x67, 0x65, 0x6f, 0x6d, 0x65, 0x74, 0x72, 0x79, 0x5f, 0x64, 0x61, + 0x74, 0x61, 0x18, 0x0a, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x22, 0x2e, 0x6d, 0x69, 0x6c, 0x76, 0x75, + 0x73, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x73, 0x63, 0x68, 0x65, 0x6d, 0x61, 0x2e, 0x47, + 0x65, 0x6f, 0x6d, 0x65, 0x74, 0x72, 0x79, 0x41, 0x72, 0x72, 0x61, 0x79, 0x48, 0x00, 0x52, 0x0c, + 0x67, 0x65, 0x6f, 0x6d, 0x65, 0x74, 0x72, 0x79, 0x44, 0x61, 0x74, 0x61, 0x42, 0x06, 0x0a, 0x04, 0x64, 0x61, 0x74, 0x61, 0x22, 0x40, 0x0a, 0x10, 0x53, 0x70, 0x61, 0x72, 0x73, 0x65, 0x46, 0x6c, 0x6f, 0x61, 0x74, 0x41, 0x72, 0x72, 0x61, 0x79, 0x12, 0x1a, 0x0a, 0x08, 0x63, 0x6f, 0x6e, 0x74, 0x65, 0x6e, 0x74, 0x73, 0x18, 0x01, 0x20, 0x03, 0x28, 0x0c, 0x52, 0x08, 0x63, 0x6f, 0x6e, 0x74, @@ -2617,13 +2688,13 @@ var file_schema_proto_depIdxs = []int32{ 27, // 2: milvus.proto.schema.FieldSchema.index_params:type_name -> milvus.proto.common.KeyValuePair 2, // 3: milvus.proto.schema.FieldSchema.state:type_name -> milvus.proto.schema.FieldState 0, // 4: milvus.proto.schema.FieldSchema.element_type:type_name -> milvus.proto.schema.DataType - 15, // 5: milvus.proto.schema.FieldSchema.default_value:type_name -> milvus.proto.schema.ValueField + 16, // 5: milvus.proto.schema.FieldSchema.default_value:type_name -> milvus.proto.schema.ValueField 1, // 6: milvus.proto.schema.FunctionSchema.type:type_name -> milvus.proto.schema.FunctionType 27, // 7: milvus.proto.schema.FunctionSchema.params:type_name -> milvus.proto.common.KeyValuePair 3, // 8: milvus.proto.schema.CollectionSchema.fields:type_name -> milvus.proto.schema.FieldSchema 27, // 9: milvus.proto.schema.CollectionSchema.properties:type_name -> milvus.proto.common.KeyValuePair 4, // 10: milvus.proto.schema.CollectionSchema.functions:type_name -> milvus.proto.schema.FunctionSchema - 16, // 11: milvus.proto.schema.ArrayArray.data:type_name -> milvus.proto.schema.ScalarField + 17, // 11: milvus.proto.schema.ArrayArray.data:type_name -> milvus.proto.schema.ScalarField 0, // 12: milvus.proto.schema.ArrayArray.element_type:type_name -> milvus.proto.schema.DataType 6, // 13: milvus.proto.schema.ScalarField.bool_data:type_name -> milvus.proto.schema.BoolArray 7, // 14: milvus.proto.schema.ScalarField.int_data:type_name -> milvus.proto.schema.IntArray @@ -2809,7 +2880,7 @@ func file_schema_proto_init() { } } file_schema_proto_msgTypes[12].Exporter = func(v interface{}, i int) interface{} { - switch v := v.(*ValueField); i { + switch v := v.(*GeometryArray); i { case 0: return &v.state case 1: @@ -2821,7 +2892,7 @@ func file_schema_proto_init() { } } file_schema_proto_msgTypes[13].Exporter = func(v interface{}, i int) interface{} { - switch v := v.(*ScalarField); i { + switch v := v.(*ValueField); i { case 0: return &v.state case 1: @@ -2833,7 +2904,7 @@ func file_schema_proto_init() { } } file_schema_proto_msgTypes[14].Exporter = func(v interface{}, i int) interface{} { - switch v := v.(*SparseFloatArray); i { + switch v := v.(*ScalarField); i { case 0: return &v.state case 1: @@ -2845,7 +2916,7 @@ func file_schema_proto_init() { } } file_schema_proto_msgTypes[15].Exporter = func(v interface{}, i int) interface{} { - switch v := v.(*VectorField); i { + switch v := v.(*SparseFloatArray); i { case 0: return &v.state case 1: @@ -2857,7 +2928,7 @@ func file_schema_proto_init() { } } file_schema_proto_msgTypes[16].Exporter = func(v interface{}, i int) interface{} { - switch v := v.(*FieldData); i { + switch v := v.(*VectorField); i { case 0: return &v.state case 1: @@ -2869,7 +2940,7 @@ func file_schema_proto_init() { } } file_schema_proto_msgTypes[17].Exporter = func(v interface{}, i int) interface{} { - switch v := v.(*IDs); i { + switch v := v.(*FieldData); i { case 0: return &v.state case 1: @@ -2881,7 +2952,7 @@ func file_schema_proto_init() { } } file_schema_proto_msgTypes[18].Exporter = func(v interface{}, i int) interface{} { - switch v := v.(*SearchResultData); i { + switch v := v.(*IDs); i { case 0: return &v.state case 1: @@ -2893,7 +2964,7 @@ func file_schema_proto_init() { } } file_schema_proto_msgTypes[19].Exporter = func(v interface{}, i int) interface{} { - switch v := v.(*VectorClusteringInfo); i { + switch v := v.(*SearchResultData); i { case 0: return &v.state case 1: @@ -2905,7 +2976,7 @@ func file_schema_proto_init() { } } file_schema_proto_msgTypes[20].Exporter = func(v interface{}, i int) interface{} { - switch v := v.(*ScalarClusteringInfo); i { + switch v := v.(*VectorClusteringInfo); i { case 0: return &v.state case 1: @@ -2917,6 +2988,18 @@ func file_schema_proto_init() { } } file_schema_proto_msgTypes[21].Exporter = func(v interface{}, i int) interface{} { + switch v := v.(*ScalarClusteringInfo); i { + case 0: + return &v.state + case 1: + return &v.sizeCache + case 2: + return &v.unknownFields + default: + return nil + } + } + file_schema_proto_msgTypes[22].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*ClusteringInfo); i { case 0: return &v.state @@ -2962,7 +3045,7 @@ func file_schema_proto_init() { (*ValueField_StringData)(nil), (*ValueField_BytesData)(nil), } - file_schema_proto_msgTypes[13].OneofWrappers = []interface{}{ + file_schema_proto_msgTypes[14].OneofWrappers = []interface{}{ (*ScalarField_BoolData)(nil), (*ScalarField_IntData)(nil), (*ScalarField_LongData)(nil), @@ -2972,19 +3055,20 @@ func file_schema_proto_init() { (*ScalarField_BytesData)(nil), (*ScalarField_ArrayData)(nil), (*ScalarField_JsonData)(nil), + (*ScalarField_GeometryData)(nil), } - file_schema_proto_msgTypes[15].OneofWrappers = []interface{}{ + file_schema_proto_msgTypes[16].OneofWrappers = []interface{}{ (*VectorField_FloatVector)(nil), (*VectorField_BinaryVector)(nil), (*VectorField_Float16Vector)(nil), (*VectorField_Bfloat16Vector)(nil), (*VectorField_SparseFloatVector)(nil), } - file_schema_proto_msgTypes[16].OneofWrappers = []interface{}{ + file_schema_proto_msgTypes[17].OneofWrappers = []interface{}{ (*FieldData_Scalars)(nil), (*FieldData_Vectors)(nil), } - file_schema_proto_msgTypes[17].OneofWrappers = []interface{}{ + file_schema_proto_msgTypes[18].OneofWrappers = []interface{}{ (*IDs_IntId)(nil), (*IDs_StrId)(nil), } diff --git a/proto/schema.proto b/proto/schema.proto index 19554d7..74e1209 100644 --- a/proto/schema.proto +++ b/proto/schema.proto @@ -31,6 +31,7 @@ enum DataType { VarChar = 21; // variable-length strings with a specified maximum length Array = 22; JSON = 23; + Geometry = 24; BinaryVector = 100; FloatVector = 101; @@ -122,6 +123,8 @@ message ArrayArray { message JSONArray { repeated bytes data = 1; } +message GeometryArray { repeated bytes data = 1; } + message ValueField { oneof data { bool bool_data = 1; @@ -145,6 +148,7 @@ message ScalarField { BytesArray bytes_data = 7; ArrayArray array_data = 8; JSONArray json_data = 9; + GeometryArray geometry_data = 10; } }