Commit 0ec7a55
authored
feat: add support for vector search and query explain (#125)
This commit introduces two major features: Firestore Vector Search and Query Explain functionality.
**Vector Search:**
- Adds `FieldValue.vector()` to create `VectorValue` objects for storing vector embeddings in documents.
- Introduces `query.findNearest()` to perform vector similarity searches. This returns a `VectorQuery` which can be executed with `.get()`.
- Adds `VectorQuerySnapshot` to represent the results of a vector search.
- New types `VectorQueryOptions` and `DistanceMeasure` are added to configure vector queries.
**Query Explain:**
- Adds `query.explain(options)` and `vectorQuery.explain(options)` methods.
- These methods return an `ExplainResults` object containing `ExplainMetrics` with plan summaries and optional execution statistics.
- New types `ExplainOptions`, `ExplainResults`, `ExplainMetrics`, `PlanSummary`, and `ExecutionStats` are introduced.
**Other Changes:**
- Adds `size` and `empty` getters to `QuerySnapshot`.
- Extends the internal testing helper `firestore.snapshot_()` to support creating snapshots for missing documents.1 parent fbfd1ff commit 0ec7a55
File tree
37 files changed
+2891
-550
lines changed- .github/workflows
- packages
- dart_firebase_admin
- example
- lib
- test
- app
- auth
- firestore
- messaging
- googleapis_firestore
- lib
- src
- reference
- test
- scripts
37 files changed
+2891
-550
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
128 | 128 | | |
129 | 129 | | |
130 | 130 | | |
131 | | - | |
| 131 | + | |
132 | 132 | | |
133 | 133 | | |
| 134 | + | |
| 135 | + | |
| 136 | + | |
| 137 | + | |
| 138 | + | |
| 139 | + | |
| 140 | + | |
| 141 | + | |
| 142 | + | |
| 143 | + | |
| 144 | + | |
| 145 | + | |
| 146 | + | |
| 147 | + | |
| 148 | + | |
| 149 | + | |
| 150 | + | |
| 151 | + | |
| 152 | + | |
| 153 | + | |
| 154 | + | |
| 155 | + | |
| 156 | + | |
| 157 | + | |
| 158 | + | |
| 159 | + | |
| 160 | + | |
| 161 | + | |
134 | 162 | | |
135 | 163 | | |
136 | 164 | | |
137 | 165 | | |
138 | | - | |
139 | | - | |
140 | | - | |
| 166 | + | |
| 167 | + | |
| 168 | + | |
| 169 | + | |
| 170 | + | |
| 171 | + | |
| 172 | + | |
| 173 | + | |
| 174 | + | |
| 175 | + | |
| 176 | + | |
| 177 | + | |
| 178 | + | |
| 179 | + | |
| 180 | + | |
| 181 | + | |
| 182 | + | |
| 183 | + | |
| 184 | + | |
| 185 | + | |
| 186 | + | |
| 187 | + | |
| 188 | + | |
| 189 | + | |
| 190 | + | |
| 191 | + | |
| 192 | + | |
| 193 | + | |
| 194 | + | |
| 195 | + | |
| 196 | + | |
| 197 | + | |
| 198 | + | |
| 199 | + | |
| 200 | + | |
141 | 201 | | |
142 | 202 | | |
143 | 203 | | |
| |||
147 | 207 | | |
148 | 208 | | |
149 | 209 | | |
| 210 | + | |
150 | 211 | | |
151 | 212 | | |
152 | 213 | | |
153 | | - | |
154 | | - | |
| 214 | + | |
| 215 | + | |
| 216 | + | |
| 217 | + | |
| 218 | + | |
| 219 | + | |
| 220 | + | |
| 221 | + | |
| 222 | + | |
| 223 | + | |
| 224 | + | |
| 225 | + | |
155 | 226 | | |
156 | 227 | | |
157 | 228 | | |
| |||
170 | 241 | | |
171 | 242 | | |
172 | 243 | | |
| 244 | + | |
| 245 | + | |
| 246 | + | |
173 | 247 | | |
174 | 248 | | |
175 | 249 | | |
176 | 250 | | |
177 | 251 | | |
178 | | - | |
| 252 | + | |
179 | 253 | | |
180 | 254 | | |
| 255 | + | |
| 256 | + | |
| 257 | + | |
| 258 | + | |
| 259 | + | |
| 260 | + | |
| 261 | + | |
181 | 262 | | |
182 | 263 | | |
183 | 264 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
2 | 2 | | |
3 | 3 | | |
4 | 4 | | |
5 | | - | |
6 | 5 | | |
7 | 6 | | |
8 | 7 | | |
| |||
11 | 10 | | |
12 | 11 | | |
13 | 12 | | |
14 | | - | |
| 13 | + | |
15 | 14 | | |
16 | 15 | | |
17 | 16 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
2 | 2 | | |
3 | | - | |
4 | 3 | | |
5 | 4 | | |
6 | | - | |
| 5 | + | |
7 | 6 | | |
8 | 7 | | |
9 | | - | |
10 | | - | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
Lines changed: 28 additions & 59 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
10 | 10 | | |
11 | 11 | | |
12 | 12 | | |
13 | | - | |
14 | 13 | | |
15 | 14 | | |
16 | 15 | | |
| |||
235 | 234 | | |
236 | 235 | | |
237 | 236 | | |
238 | | - | |
| 237 | + | |
239 | 238 | | |
240 | 239 | | |
241 | 240 | | |
| |||
267 | 266 | | |
268 | 267 | | |
269 | 268 | | |
270 | | - | |
271 | | - | |
272 | | - | |
273 | | - | |
274 | | - | |
275 | | - | |
276 | | - | |
277 | | - | |
278 | | - | |
279 | | - | |
280 | | - | |
| 269 | + | |
| 270 | + | |
| 271 | + | |
| 272 | + | |
| 273 | + | |
| 274 | + | |
281 | 275 | | |
282 | | - | |
| 276 | + | |
283 | 277 | | |
284 | | - | |
285 | | - | |
| 278 | + | |
286 | 279 | | |
287 | 280 | | |
288 | 281 | | |
289 | 282 | | |
290 | 283 | | |
291 | 284 | | |
292 | 285 | | |
293 | | - | |
294 | | - | |
295 | | - | |
296 | | - | |
297 | | - | |
298 | | - | |
299 | | - | |
300 | | - | |
301 | | - | |
| 286 | + | |
| 287 | + | |
| 288 | + | |
302 | 289 | | |
303 | 290 | | |
304 | 291 | | |
| |||
334 | 321 | | |
335 | 322 | | |
336 | 323 | | |
337 | | - | |
| 324 | + | |
338 | 325 | | |
339 | 326 | | |
340 | 327 | | |
341 | 328 | | |
342 | 329 | | |
343 | 330 | | |
344 | | - | |
345 | | - | |
| 331 | + | |
| 332 | + | |
346 | 333 | | |
347 | 334 | | |
348 | 335 | | |
349 | 336 | | |
350 | 337 | | |
351 | 338 | | |
352 | | - | |
353 | | - | |
354 | | - | |
355 | | - | |
356 | | - | |
357 | | - | |
358 | | - | |
359 | | - | |
| 339 | + | |
| 340 | + | |
360 | 341 | | |
361 | 342 | | |
362 | 343 | | |
363 | 344 | | |
364 | 345 | | |
365 | 346 | | |
366 | 347 | | |
367 | | - | |
368 | | - | |
369 | | - | |
370 | | - | |
| 348 | + | |
371 | 349 | | |
372 | 350 | | |
373 | 351 | | |
374 | 352 | | |
375 | 353 | | |
376 | 354 | | |
377 | 355 | | |
378 | | - | |
379 | | - | |
380 | | - | |
381 | 356 | | |
382 | 357 | | |
383 | 358 | | |
| |||
423 | 398 | | |
424 | 399 | | |
425 | 400 | | |
426 | | - | |
| 401 | + | |
427 | 402 | | |
428 | 403 | | |
429 | 404 | | |
| |||
469 | 444 | | |
470 | 445 | | |
471 | 446 | | |
472 | | - | |
473 | | - | |
474 | | - | |
475 | | - | |
476 | | - | |
477 | | - | |
478 | | - | |
479 | | - | |
480 | | - | |
| 447 | + | |
| 448 | + | |
| 449 | + | |
| 450 | + | |
481 | 451 | | |
482 | | - | |
| 452 | + | |
483 | 453 | | |
484 | | - | |
| 454 | + | |
485 | 455 | | |
486 | | - | |
487 | | - | |
| 456 | + | |
488 | 457 | | |
489 | 458 | | |
490 | 459 | | |
491 | | - | |
| 460 | + | |
492 | 461 | | |
493 | 462 | | |
494 | 463 | | |
| |||
532 | 501 | | |
533 | 502 | | |
534 | 503 | | |
535 | | - | |
| 504 | + | |
536 | 505 | | |
537 | 506 | | |
538 | 507 | | |
| |||
0 commit comments