mirror of
https://gitee.com/milvus-io/milvus.git
synced 2025-12-06 17:18:35 +08:00
Related to #42148 Add comprehensive support for struct array field type in the Go SDK, including data structure definitions, column operations, schema construction, and full test coverage. **Struct Array Column Implementation (`client/column/struct.go`)** - Add `columnStructArray` type to handle struct array fields - Implement `Column` interface methods: - `NewColumnStructArray()`: Create new struct array column from sub-fields - `Name()`, `Type()`: Basic metadata accessors - `Slice()`: Support slicing across all sub-fields - `FieldData()`: Convert to protobuf `StructArrayField` format - `Get()`: Retrieve struct values as `map[string]any` - `ValidateNullable()`, `CompactNullableValues()`: Nullable support - Placeholder implementations for unsupported operations (AppendValue, GetAsX, IsNull, AppendNull) **Struct Array Parsing (`client/column/columns.go`)** - Add `parseStructArrayData()` function to parse `StructArrayField` from protobuf - Update `FieldDataColumn()` to detect and parse struct array fields - Support range-based slicing for struct array data --------- Signed-off-by: Congqi Xia <congqi.xia@zilliz.com>
54 lines
1.9 KiB
Go
54 lines
1.9 KiB
Go
// Licensed to the LF AI & Data foundation under one
|
|
// or more contributor license agreements. See the NOTICE file
|
|
// distributed with this work for additional information
|
|
// regarding copyright ownership. The ASF licenses this file
|
|
// to you under the Apache License, Version 2.0 (the
|
|
// "License"); you may not use this file except in compliance
|
|
// with the License. You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
package entity
|
|
|
|
import "github.com/milvus-io/milvus-proto/go-api/v2/commonpb"
|
|
|
|
// MetricType metric type
|
|
type MetricType string
|
|
|
|
// Metric Constants
|
|
const (
|
|
L2 MetricType = "L2"
|
|
IP MetricType = "IP"
|
|
COSINE MetricType = "COSINE"
|
|
HAMMING MetricType = "HAMMING"
|
|
JACCARD MetricType = "JACCARD"
|
|
TANIMOTO MetricType = "TANIMOTO"
|
|
SUBSTRUCTURE MetricType = "SUBSTRUCTURE"
|
|
SUPERSTRUCTURE MetricType = "SUPERSTRUCTURE"
|
|
BM25 MetricType = "BM25"
|
|
MHJACCARD MetricType = "MHJACCARD"
|
|
|
|
// The same with MaxSimCosine
|
|
MaxSim MetricType = "MAX_SIM"
|
|
MaxSimCosine MetricType = "MAX_SIM_COSINE"
|
|
MaxSimL2 MetricType = "MAX_SIM_L2"
|
|
MaxSimIP MetricType = "MAX_SIM_IP"
|
|
MaxSimHamming MetricType = "MAX_SIM_HAMMING"
|
|
MaxSimJaccard MetricType = "MAX_SIM_JACCARD"
|
|
)
|
|
|
|
// CompactionState enum type for compaction state
|
|
type CompactionState commonpb.CompactionState
|
|
|
|
// CompactionState Constants
|
|
const (
|
|
CompactionStateRunning CompactionState = CompactionState(commonpb.CompactionState_Executing)
|
|
CompactionStateCompleted CompactionState = CompactionState(commonpb.CompactionState_Completed)
|
|
)
|