IteratorExample.java 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167
  1. package io.milvus.v2;
  2. import com.google.common.collect.Lists;
  3. import com.google.gson.Gson;
  4. import com.google.gson.JsonObject;
  5. import io.milvus.orm.iterator.QueryIterator;
  6. import io.milvus.orm.iterator.SearchIterator;
  7. import io.milvus.response.QueryResultsWrapper;
  8. import io.milvus.v1.CommonUtils;
  9. import io.milvus.v2.client.ConnectConfig;
  10. import io.milvus.v2.client.MilvusClientV2;
  11. import io.milvus.v2.common.ConsistencyLevel;
  12. import io.milvus.v2.common.DataType;
  13. import io.milvus.v2.common.IndexParam;
  14. import io.milvus.v2.service.collection.request.AddFieldReq;
  15. import io.milvus.v2.service.collection.request.CreateCollectionReq;
  16. import io.milvus.v2.service.collection.request.DropCollectionReq;
  17. import io.milvus.v2.service.vector.request.InsertReq;
  18. import io.milvus.v2.service.vector.request.QueryIteratorReq;
  19. import io.milvus.v2.service.vector.request.QueryReq;
  20. import io.milvus.v2.service.vector.request.SearchIteratorReq;
  21. import io.milvus.v2.service.vector.request.data.FloatVec;
  22. import io.milvus.v2.service.vector.response.InsertResp;
  23. import io.milvus.v2.service.vector.response.QueryResp;
  24. import java.util.*;
  25. public class IteratorExample {
  26. private static final String COLLECTION_NAME = "java_sdk_example_iterator_v2";
  27. private static final String ID_FIELD = "userID";
  28. private static final String AGE_FIELD = "userAge";
  29. private static final String VECTOR_FIELD = "userFace";
  30. private static final Integer VECTOR_DIM = 128;
  31. public static void main(String[] args) {
  32. ConnectConfig config = ConnectConfig.builder()
  33. .uri("http://localhost:19530")
  34. .build();
  35. MilvusClientV2 client = new MilvusClientV2(config);
  36. // Create collection
  37. CreateCollectionReq.CollectionSchema collectionSchema = CreateCollectionReq.CollectionSchema.builder()
  38. .build();
  39. collectionSchema.addField(AddFieldReq.builder()
  40. .fieldName(ID_FIELD)
  41. .dataType(DataType.Int64)
  42. .isPrimaryKey(Boolean.TRUE)
  43. .autoID(Boolean.FALSE)
  44. .build());
  45. collectionSchema.addField(AddFieldReq.builder()
  46. .fieldName(AGE_FIELD)
  47. .dataType(DataType.Int32)
  48. .build());
  49. collectionSchema.addField(AddFieldReq.builder()
  50. .fieldName(VECTOR_FIELD)
  51. .dataType(DataType.FloatVector)
  52. .dimension(VECTOR_DIM)
  53. .build());
  54. List<IndexParam> indexParams = new ArrayList<>();
  55. indexParams.add(IndexParam.builder()
  56. .fieldName(VECTOR_FIELD)
  57. .indexType(IndexParam.IndexType.FLAT)
  58. .metricType(IndexParam.MetricType.L2)
  59. .build());
  60. // Drop collection if exists
  61. client.dropCollection(DropCollectionReq.builder()
  62. .collectionName(COLLECTION_NAME)
  63. .build());
  64. // Create collection
  65. CreateCollectionReq requestCreate = CreateCollectionReq.builder()
  66. .collectionName(COLLECTION_NAME)
  67. .collectionSchema(collectionSchema)
  68. .indexParams(indexParams)
  69. .build();
  70. client.createCollection(requestCreate);
  71. // Insert rows
  72. long count = 10000;
  73. List<JsonObject> rowsData = new ArrayList<>();
  74. Random ran = new Random();
  75. Gson gson = new Gson();
  76. for (long i = 0L; i < count; ++i) {
  77. JsonObject row = new JsonObject();
  78. row.addProperty(ID_FIELD, i);
  79. row.addProperty(AGE_FIELD, ran.nextInt(99));
  80. row.add(VECTOR_FIELD, gson.toJsonTree(CommonUtils.generateFloatVector(VECTOR_DIM)));
  81. rowsData.add(row);
  82. }
  83. InsertResp insertResp = client.insert(InsertReq.builder()
  84. .collectionName(COLLECTION_NAME)
  85. .data(rowsData)
  86. .build());
  87. // Check row count
  88. QueryResp queryResp = client.query(QueryReq.builder()
  89. .collectionName(COLLECTION_NAME)
  90. .filter("")
  91. .outputFields(Collections.singletonList("count(*)"))
  92. .consistencyLevel(ConsistencyLevel.STRONG)
  93. .build());
  94. List<QueryResp.QueryResult> queryResults = queryResp.getQueryResults();
  95. System.out.printf("Inserted row count: %d\n", queryResults.get(0).getEntity().get("count(*)"));
  96. // Search iterator
  97. SearchIterator searchIterator = client.searchIterator(SearchIteratorReq.builder()
  98. .collectionName(COLLECTION_NAME)
  99. .outputFields(Lists.newArrayList(AGE_FIELD))
  100. .batchSize(50L)
  101. .vectorFieldName(VECTOR_FIELD)
  102. .vectors(Collections.singletonList(new FloatVec(CommonUtils.generateFloatVector(VECTOR_DIM))))
  103. .expr(String.format("%s > 50 && %s < 100", AGE_FIELD, AGE_FIELD))
  104. .params("{\"range_filter\": 15.0, \"radius\": 20.0}")
  105. .topK(300)
  106. .metricType(IndexParam.MetricType.L2)
  107. .consistencyLevel(ConsistencyLevel.BOUNDED)
  108. .build());
  109. int counter = 0;
  110. while (true) {
  111. List<QueryResultsWrapper.RowRecord> res = searchIterator.next();
  112. if (res.isEmpty()) {
  113. System.out.println("Search iteration finished, close");
  114. searchIterator.close();
  115. break;
  116. }
  117. for (QueryResultsWrapper.RowRecord record : res) {
  118. System.out.println(record);
  119. counter++;
  120. }
  121. }
  122. System.out.printf("%d search results returned\n%n", counter);
  123. // Query iterator
  124. QueryIterator queryIterator = client.queryIterator(QueryIteratorReq.builder()
  125. .collectionName(COLLECTION_NAME)
  126. .expr(String.format("%s < 300", ID_FIELD))
  127. .outputFields(Lists.newArrayList(ID_FIELD, AGE_FIELD))
  128. .batchSize(50L)
  129. .offset(5)
  130. .limit(400)
  131. .consistencyLevel(ConsistencyLevel.BOUNDED)
  132. .build());
  133. counter = 0;
  134. while (true) {
  135. List<QueryResultsWrapper.RowRecord> res = queryIterator.next();
  136. if (res.isEmpty()) {
  137. System.out.println("query iteration finished, close");
  138. queryIterator.close();
  139. break;
  140. }
  141. for (QueryResultsWrapper.RowRecord record : res) {
  142. System.out.println(record);
  143. counter++;
  144. }
  145. }
  146. System.out.printf("%d query results returned%n", counter);
  147. client.close();
  148. }
  149. }