$type - Amazon DocumentDB

Las traducciones son generadas a través de traducción automática. En caso de conflicto entre la traducción y la version original de inglés, prevalecerá la version en inglés.

$type

El operador de $type agregación devuelve el tipo de datos BSON de un campo especificado. Esto resulta útil para identificar el tipo de datos de los valores de campo durante las operaciones de agregación.

Parámetros

  • expression: el campo o la expresión cuyo tipo se va a devolver.

Ejemplo (MongoDB Shell)

En el siguiente ejemplo, se muestra el uso $type del operador para identificar el tipo de datos del campo de precio de cada producto.

Cree documentos de muestra

db.inventory.insertMany([ { _id: 1, item: "Notebook", price: 15.99 }, { _id: 2, item: "Pen", price: "2.50" }, { _id: 3, item: "Eraser", price: 1 }, { _id: 4, item: "Ruler", price: null } ]);

Ejemplo de consulta

db.inventory.aggregate([ { $project: { item: 1, price: 1, priceType: { $type: "$price" } } } ]);

Salida

[ { _id: 1, item: 'Notebook', price: 15.99, priceType: 'double' }, { _id: 2, item: 'Pen', price: '2.50', priceType: 'string' }, { _id: 3, item: 'Eraser', price: 1, priceType: 'int' }, { _id: 4, item: 'Ruler', price: null, priceType: 'null' } ]

Ejemplos de código

Para ver un ejemplo de código para usar el operador de $type agregación, elija la pestaña correspondiente al idioma que desee usar:

Node.js
const { MongoClient } = require('mongodb'); async function example() { const client = await MongoClient.connect('mongodb://<username>:<password>@<cluster-endpoint>:27017/?tls=true&tlsCAFile=global-bundle.pem&replicaSet=rs0&readPreference=secondaryPreferred&retryWrites=false'); const db = client.db('test'); const collection = db.collection('inventory'); const result = await collection.aggregate([ { $project: { item: 1, price: 1, priceType: { $type: "$price" } } } ]).toArray(); console.log(result); await client.close(); } example();
Python
from pymongo import MongoClient def example(): client = MongoClient('mongodb://<username>:<password>@<cluster-endpoint>:27017/?tls=true&tlsCAFile=global-bundle.pem&replicaSet=rs0&readPreference=secondaryPreferred&retryWrites=false') db = client['test'] collection = db['inventory'] result = list(collection.aggregate([ { '$project': { 'item': 1, 'price': 1, 'priceType': { '$type': '$price' } } } ])) print(result) client.close() example()