milvus/reader/collection.go
bigsheeper d69c925ba5 Implement the interfaces about insertion, deletion and search
Signed-off-by: bigsheeper <yihao.dai@zilliz.com>
2020-08-28 17:29:26 +08:00

48 lines
974 B
Go

package reader
import "C"
import (
"errors"
)
type Collection struct {
CollectionPtr *C.Collection
CollectionName string
Partitions []*Partition
}
// TODO: Schema
type CollectionSchema string
func NewCollection(collectionName string, schema CollectionSchema) (*Collection, error) {
cName := C.CString(collectionName)
cSchema := C.CString(schema)
collection, status := C.NewCollection(cName, cSchema)
if status != 0 {
return nil, errors.New("create collection failed")
}
return &Collection{CollectionPtr: collection, CollectionName: collectionName}, nil
}
func DeleteCollection(collection *Collection) error {
status := C.DeleteCollection(collection.CollectionPtr)
if status != 0 {
return errors.New("delete collection failed")
}
return nil
}
func (c *Collection) GetSegments() ([]*Segment, error) {
segments, status := C.GetSegments(c.CollectionPtr)
if status != 0 {
return nil, errors.New("get segments failed")
}
return segments, nil
}