java调用milvus数据库

复制代码
package org.dromara.langchain4j.config;

import io.milvus.client.MilvusServiceClient;
import io.milvus.grpc.DataType;
import io.milvus.grpc.MutationResult;
import io.milvus.grpc.SearchResults;
import io.milvus.param.*;
import io.milvus.param.collection.CreateCollectionParam;
import io.milvus.param.collection.FieldType;
import io.milvus.param.collection.LoadCollectionParam;
import io.milvus.param.dml.InsertParam;
import io.milvus.param.dml.SearchParam;
import io.milvus.param.index.CreateIndexParam;
import io.milvus.response.QueryResultsWrapper;
import io.milvus.response.SearchResultsWrapper;

import java.util.*;

public class MilvusJavaDemo {

    // 1. 连接Milvus服务器
    private static MilvusServiceClient connectMilvus() {
        String uri = "http://localhost:19530"; // Milvus服务地址
        ConnectParam connectParam = ConnectParam.newBuilder()
                .withUri(uri)
                .build();
        return new MilvusServiceClient(connectParam);
    }

    public static void main(String[] args) {
        MilvusServiceClient client = connectMilvus();
        final String COLLECTION_NAME = "book_collection";
        final int VECTOR_DIM = 768; // 向量维度

        try {
            // 4. 加载集合到内存(搜索前必须步骤)
            R<RpcStatus> loadRes = client.loadCollection(LoadCollectionParam.newBuilder()
                    .withCollectionName(COLLECTION_NAME)
                    .build());

            // 5. 插入数据(增 - Create)
            Random ran = new Random();
            // 6. 执行向量相似性搜索(查 - Read/Query)
            // 准备一个随机向量作为查询目标
            List<Float> targetVector = new ArrayList<>();
            for (int i = 0; i < VECTOR_DIM; i++) {
                targetVector.add(ran.nextFloat());
            }
            List<List<Float>> searchVectors = Arrays.asList(targetVector);

            SearchParam searchParam = SearchParam.newBuilder()
                    .withCollectionName(COLLECTION_NAME)
                    .withVectorFieldName("book_intro")
                    .withVectors(searchVectors)
                    .withTopK(2) // 返回最相似的2条结果
                    .withMetricType(MetricType.L2)
                    .withParams("{\"nprobe\":10}") // 搜索参数
                    .addOutField("word_count") // 指定返回的标量字段
                    .build();

            R<SearchResults> searchRes = client.search(searchParam);
            if (searchRes.getStatus() == R.Status.Success.getCode()) {
                SearchResultsWrapper wrapper = new SearchResultsWrapper(searchRes.getData().getResults());
                System.out.println("\n搜索完成,结果如下:");
                for (QueryResultsWrapper.RowRecord results : wrapper.getRowRecords()) {
//                    System.out.printf("距离: %f, 数据: %s%n", results.getFieldValues(), record.getFields());
                    Map<String, Object> fieldValues = results.getFieldValues();
                    for (Map.Entry<String, Object> entry : fieldValues.entrySet()) {
                        System.out.println(entry.getKey() + ": " + entry.getValue());
                    }
                }
            }

            // 7. 删除数据(删 - Delete)
            // 构建删除表达式,例如删除 word_count < 9000 的记录
//            String deleteExpr = "word_count < 9000";
//            DeleteParam deleteParam = DeleteParam.newBuilder()
//                    .withCollectionName(COLLECTION_NAME)
//                    .withExpr(deleteExpr)
//                    .build();
//            R<MutationResult> deleteRes = client.delete(deleteParam);
//            long deleteCount = deleteRes.getData().getDeleteCnt();
//            System.out.println("\n删除操作完成,删除了 " + deleteCount + " 条记录。");

        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            // 8. 可选:删除集合(清理环境)
            // R<RpcStatus> dropRes = client.dropCollection(DropCollectionParam.newBuilder()
            //         .withCollectionName(COLLECTION_NAME)
            //         .build());
            // System.out.println("集合已删除。");

            // 关闭客户端连接
            client.close();
        }
    }
}
相关推荐
l1t16 分钟前
DeepSeek总结的 pg_regresql插件:真正可移植的 PostgreSQL 统计信息
数据库·postgresql
oradh21 分钟前
Oracle 11.2.0.1版本升级至11.2.0.4_单机环境
数据库·oracle·oracle11g·oracle升级
l1t21 分钟前
用docker安装测试crate数据库
数据库·docker·容器·cratedb
anzhxu28 分钟前
QT数据库(三):QSqlQuery使用
数据库·qt·oracle
身如柳絮随风扬28 分钟前
MySQL核心知识
数据库·mysql
德彪稳坐倒骑驴33 分钟前
Oracle 11g安装
数据库·oracle
SuniaWang35 分钟前
《Spring AI + 大模型全栈实战》学习手册系列 · 专题六:《Vue3 前端开发实战:打造企业级 RAG 问答界面》
java·前端·人工智能·spring boot·后端·spring·架构
韩立学长38 分钟前
Springboot校园跑腿业务系统0b7amk02(程序、源码、数据库、调试部署方案及开发环境)系统界面展示及获取方式置于文档末尾,可供参考。
数据库·spring boot·后端
sheji341642 分钟前
【开题答辩全过程】以 基于springboot的扶贫系统为例,包含答辩的问题和答案
java·spring boot·后端
阿贵---43 分钟前
使用XGBoost赢得Kaggle比赛
jvm·数据库·python