atlas-search-vector

star 6

Use this skill when implementing full-text search, autocomplete, or vector/semantic search and RAG with MongoDB Atlas. Trigger words: 全文検索, あいまい検索, オートコンプリート, ベクトル検索, セマンティック検索, 類似検索, Atlas Search, $search, $vectorSearch, RAG, embedding.

Akira-Papa By Akira-Papa schedule Updated 5/24/2026

name: atlas-search-vector description: Use this skill when implementing full-text search, autocomplete, or vector/semantic search and RAG with MongoDB Atlas. Trigger words: 全文検索, あいまい検索, オートコンプリート, ベクトル検索, セマンティック検索, 類似検索, Atlas Search, $search, $vectorSearch, RAG, embedding.

Atlas Search & Vector Search

いつ使うか

  • 全文検索・あいまい検索・オートコンプリートを実装するとき。
  • 埋め込み(embedding)を使ったベクトル/セマンティック検索や RAG を作るとき。
  • find の正規表現検索が遅い・精度不足なとき。

やること

  • 全文検索は Atlas Search Index を作り、$search ステージで使う。
  • ベクトル検索は Vector Search Index を作り、$vectorSearch で近傍探索する。
  • 埋め込みは AI SDK 6 経由で生成し、次元数をインデックス定義と一致させる。
  • ハイブリッド検索(全文 + ベクトル)はスコア結合で精度を上げる。
  • 検索クエリ文字列も Zod で長さ・型を検証する。

守るルール

  • ✅ Search / Vector Index は Atlas 側で明示定義(コードと次元・パスを一致)。
  • $vectorSearch には numCandidateslimit を適切に設定。
  • ✅ 埋め込み生成のモデル/次元を ADR に記録する。
  • ❌ 正規表現 $regex で全件スキャンの代替にしない(遅い)。
  • ❌ API キー(埋め込み生成用)をクライアントへ露出しない。

典型例(コード片)

// ベクトル検索(セマンティック近傍)
const queryVector = await embed(queryText); // AI SDK 6, server-only
const hits = await DocModel.aggregate([
  {
    $vectorSearch: {
      index: 'doc_vector_index',
      path: 'embedding',
      queryVector,
      numCandidates: 200,
      limit: 10,
    },
  },
  { $project: { title: 1, score: { $meta: 'vectorSearchScore' } } },
]);

アンチパターン

  • インデックス未作成のまま $search を呼びエラー/低速になる。
  • 埋め込み次元の不一致(例:1536 で作って 768 を投げる)。
  • 埋め込み生成をクライアント側で行い API キーを漏らす。
Install via CLI
npx skills add https://github.com/Akira-Papa/claude-code-nextjs-mongo-template-1 --skill atlas-search-vector
Repository Details
star Stars 6
call_split Forks 6
navigation Branch main
article Path SKILL.md
More from Creator