// 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. #pragma once #include #include "common/EasyAssert.h" #include "common/Types.h" #include "common/Vector.h" #include "exec/expression/Expr.h" #include "exec/expression/Element.h" #include "segcore/SegmentInterface.h" namespace milvus { namespace exec { template struct TermElementFuncSet { bool operator()(const std::unordered_set& srcs, T val) { return srcs.find(val) != srcs.end(); } }; template struct TermIndexFunc { typedef std:: conditional_t, std::string, T> IndexInnerType; using Index = index::ScalarIndex; TargetBitmap operator()(Index* index, size_t n, const IndexInnerType* val) { return index->In(n, val); } }; class PhyTermFilterExpr : public SegmentExpr { public: PhyTermFilterExpr( const std::vector>& input, const std::shared_ptr& expr, const std::string& name, const segcore::SegmentInternalInterface* segment, int64_t active_count, milvus::Timestamp timestamp, int64_t batch_size, int32_t consistency_level) : SegmentExpr(std::move(input), name, segment, expr->column_.field_id_, expr->column_.nested_path_, expr->vals_.size() == 0 ? DataType::NONE : FromValCase(expr->vals_[0].val_case()), active_count, batch_size, consistency_level), expr_(expr), query_timestamp_(timestamp) { } void Eval(EvalCtx& context, VectorPtr& result) override; bool IsSource() const override { return true; } std::string ToString() const { return fmt::format("{}", expr_->ToString()); } std::optional GetColumnInfo() const override { return expr_->column_; } private: void InitPkCacheOffset(); template bool CanSkipSegment(); VectorPtr ExecPkTermImpl(); template VectorPtr ExecVisitorImpl(EvalCtx& context); template VectorPtr ExecVisitorImplForIndex(); template VectorPtr ExecVisitorImplForData(EvalCtx& context); template VectorPtr ExecVisitorImplTemplateJson(EvalCtx& context); template VectorPtr ExecTermJsonVariableInField(EvalCtx& context); template VectorPtr ExecTermJsonFieldInVariable(EvalCtx& context); template VectorPtr ExecVisitorImplTemplateArray(EvalCtx& context); template VectorPtr ExecTermArrayVariableInField(EvalCtx& context); template VectorPtr ExecTermArrayFieldInVariable(EvalCtx& context); template VectorPtr ExecJsonInVariableByKeyIndex(); private: std::shared_ptr expr_; milvus::Timestamp query_timestamp_; bool cached_bits_inited_{false}; TargetBitmap cached_bits_; bool arg_inited_{false}; std::shared_ptr arg_set_; std::shared_ptr arg_set_float_; SingleElement arg_val_; int32_t consistency_level_ = 0; }; } //namespace exec } // namespace milvus