• Jobs
  • About Us
  • professionals
    • Home
    • Jobs
    • Courses and challenges
  • business
    • Home
    • Post vacancy
    • Our process
    • Pricing
    • Assessments
    • Payroll
    • Blog
    • Sales
    • Salary Calculator

0

193
Views
Operación de parche masivo @azure/cosmos javascript sdk

Tengo un contenedor de guías de costos en mi Azure Cosmos DB (usando la API de SQL central). Cada guía de costos tiene una variedad de materiales. Necesito agregar un material a esta matriz en cada documento del contenedor. ¿Es esto posible con javascript en una sola transacción? Estoy familiarizado con la actualización parcial de documentos individualmente mediante la operación de parche, pero preferiría hacerlo todo de una vez si es posible. Estoy usando el paquete @azure/cosmos versión 3.15

Así es como actualizo documentos individuales en mi aplicación de funciones:

 const CosmosClient = require('@azure/cosmos').CosmosClient; const config = require('../config/config'); const { endpoint, key, databaseId } = config; const client = new CosmosClient({ endpoint, key }); const database = client.database(databaseId); module.exports = async function (context, req) { const containerId = req.query.containerId; const container = database.container(containerId); const id = req.query.id; const updates = req.body; const querySpec = { query: `SELECT * from c where c.id = "${id}"` } const { resources: items } = await container.items .query(querySpec) .fetchAll() const patchOp = []; // loop through updates object Object.keys(updates).map(key => { patchOp.push({ op: 'replace', path: `/${key}`, value: updates[key] }) }) const { resource: patchSource } = await container.item(items[0].id, items[0].id).patch(patchOp); }
about 3 years ago · Juan Pablo Isaza
2 answers
Answer question

0

Técnicamente, hasta ahora no está disponible este tipo de transacción única usando Java Script. Hay otras posibilidades, como usar .NET, que se usan para requisitos similares.

Otros lenguajes como JAVA y PYTHON tienen una implementación parcial. Terraform también puede ayudar un poco en la implementación parcial.

https://docs.microsoft.com/en-us/azure/cosmos-db/sql/sql-api-sdk-bulk-executor-dot-net

about 3 years ago · Juan Pablo Isaza Report

0

Lo más cercano que he visto es usar la operación a granel o por lotes en artículos dentro de un contenedor. Por ejemplo:

 const operations = [ { operationType: "Create", resourceBody: { id: "doc1", name: "sample", key: "A" } }, { operationType: "Upsert", partitionKey: 'A', resourceBody: { id: "doc2", name: "other", key: "A" } } ]; await database.container.items.batch(operations);

Enlace a la documentación de Azure: https://docs.microsoft.com/en-us/javascript/api/@azure/cosmos/items?view=azure-node-latest#@azure-cosmos-items-batch

about 3 years ago · Juan Pablo Isaza Report
Answer question
Find remote jobs

Discover the new way to find a job!

Top jobs
Top job categories
Business
Post vacancy Pricing Our process Sales
Legal
Terms and conditions Privacy policy
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recommend me some offers
I have an error