Para simplificar a transição da pesquisa vetorial 1.0, um novo recurso foi introduzido na API ImportDataObjects.
O processo de migração envolve três etapas principais:
Crie uma coleção com um esquema correspondente. Antes de importar, você precisa criar uma coleção. O esquema de dados precisa ser estruturado para acomodar os dados transformados da Pesquisa vetorial 1.0.
Inicie o processo de importação. Chame a API
ImportDataObjects, especificando o local do Cloud Storage dos dados da pesquisa vetorial 1.0 e ativando a flag de conversãodetect_and_convert_vs1_json.Entenda a transformação de dados. Saiba como seus campos de dados da Pesquisa de vetor 1.0 são mapeados para a nova estrutura de objeto de dados.
Criar uma Coleção
Primeiro, crie uma coleção com um esquema de dados que reflita a estrutura dos seus dados da Pesquisa vetorial 1.0.
curl -X POST \
'https://vectorsearch.googleapis.com/v1beta/projects/PROJECT_ID/locations/LOCATION/collections?collection_id=movies' \
-H 'Bearer $(gcloud auth print-access-token)' \
-H 'Content-Type: application/json' \
-d '{ \
"data_schema": { \
"$schema": "http://json-schema.org/draft-07/schema#", \
"type": "object", \
"properties": { \
"restricts": { \
"type": "object", \
"properties": { \
"genres": { \
"type": "array", \
"items": { \
"type": "string" \
} \
}, \
"director": { \
"type": "array", \
"items": { \
"type": "string" \
} \
} \
} \
}, \
"restricts_deny": { \
"type": "object", \
"properties": { \
"genres": { \
"type": "array", \
"items": { \
"type": "string" \
} \
} \
} \
}, \
"numeric_restricts": { \
"type": "object", \
"properties": { \
"year": { \
"type": "integer" \
}, \
"imdb_rating": { \
"type": "number", \
"format": "float" \
} \
} \
}, \
"embedding_metadata": { \
"type": "object", \
"properties": { \
"plot": { \
"type": "string" \
}, \
"customers_review_summary": { \
"type": "string" \
}, \
"critics_review_summary": { \
"type": "string" \
} \
}, \
} \
} \
}, \
"vector_schema": { \
"embedding": { \
"dense_vector": { \
"dimensions": 768 \
} \
}, \
"sparse_embedding": { \
"sparse_vector": {} \
} \
} \
}'
Importar seus dados da Pesquisa vetorial 1.0
Em seguida, use a API ImportDataObjects na coleção recém-criada.
Aponte para o bucket do Cloud Storage que contém seus dados da Pesquisa vetorial 1.0.
curl -X POST \
"https://vectorsearch.googleapis.com/v1beta/projects/PROJECT_ID/locations/LOCATION/collections/COLLECTION_ID:importDataObjects" \
-H "Authorization: Bearer $(gcloud auth print-access-token)" \
-H "Content-Type: application/json" \
-d '{ \
"gcs_import": { \
"contents_uri": "gs://your-bucket/path/to/your-data.jsonl", \
"error_uri": "gs://your-bucket/path/to/import-errors/" \
} \
}'
Transformação de dados
Durante o processo de importação, os dados da pesquisa vetorial 1.0 serão transformados em objetos de dados da pesquisa vetorial 2.0. Os exemplos a seguir ilustram como os campos são mapeados.
Formato de arquivo do Cloud Storage da pesquisa vetorial 1.0
{
"id": "movie-789",
"embedding": [-0.23, 0.88, 0.11, ...],
"sparse_embedding": {"values": [0.1, 0.2], "dimensions": [1, 4]},
"restricts": [
{"namespace": "genres", "allow": ["science-fiction", "action"], "deny": ["horror"]},
{"namespace": "director", "allow": ["Christopher Nolan"]}
],
"numeric_restricts": [
{"namespace": "year", "value_int": 2010},
{"namespace": "imdb_rating", "value_float": 8.8}
],
"embedding_metadata": {
"plot": "...",
"customers_review_summary": "...",
"critics_review_summary": "..."
}
}
Objeto de dados da pesquisa vetorial transformada 2.0
DataObject(
name="/.../movie-789",
data={
"restricts": {
"genres": ["science-fiction", "action"],
"director": ["Christopher Nolan"],
},
"restricts_deny": {
"genres": ["horror"]
},
"numeric_restricts": {
"year": 2010,
"imdb_rating": 8.8,
},
"embedding_metadata": {
"plot": "...",
"customers_review_summary": "...",
"critics_review_summary": "...",
}
},
vectors={
"embedding": {"dense_vector": {"values": [-0.23, 0.88, 0.11, ...]}},
"sparse_embedding": {"sparse_vector": {"values": [0.1, 0.2], "indices": [1, 4]}},
}
)