Overview
Dentro de una colección, diferentes documentos pueden contener distintos valores para un mismo campo. Por ejemplo, uno restaurant Un documento tiene un valor borough de "Manhattan" y otro tiene un valor borough de "Queens". Con PyMongo, puede recuperar todos los valores distintos que contiene un campo en varios documentos de una colección.
Datos de muestra
Los ejemplos de esta guía utilizan la colección sample_restaurants.restaurants de Conjuntos de datos de muestra de Atlas. Para aprender a crear un clúster gratuito de MongoDB Atlas y cargar los conjuntos de datos de muestra, consulte
Comience a utilizar PyMongo.
distinct() Método
Para recuperar los valores distintos de un campo específico, llame al método distinct() y pase el nombre del campo para el cual desea encontrar valores distintos.
Recuperar valores distintos en una colección
El siguiente ejemplo recupera los valores distintos del campo borough en la colección restaurants. Seleccione el Synchronous o pestaña Asynchronous para ver el código correspondiente:
results = restaurants.distinct("borough") for restaurant in results: print(restaurant)
Bronx Brooklyn Manhattan Missing Queens Staten Island
results = await restaurants.distinct("borough") for restaurant in results: print(restaurant)
Bronx Brooklyn Manhattan Missing Queens Staten Island
Los resultados muestran todos los valores distintos que aparecen en el campo borough en todos los documentos de la colección. Aunque varios documentos tienen el mismo valor en el campo borough, cada valor aparece solo una vez en los resultados.
Recupere valores distintos en documentos especificados
Puede aplicar un filtro de consulta al distinct() método para encontrar los distintos valores de campo en un subconjunto de documentos de una colección. Un filtro de consulta es una expresión que especifica los criterios de búsqueda utilizados para encontrar documentos en una operación. Para obtener más información sobre cómo crear un filtro de consulta, consulte Especificar una consulta.
El siguiente ejemplo recupera los valores distintos del campo borough para todos los documentos cuyo valor de campo cuisine es "Italian". Seleccione la pestaña Synchronous o Asynchronous para ver el código correspondiente:
results = restaurants.distinct("borough", { "cuisine": "Italian" }) for restaurant in results: print(restaurant)
Bronx Brooklyn Manhattan Queens Staten Island
results = await restaurants.distinct("borough", { "cuisine": "Italian" }) for restaurant in results: print(restaurant)
Bronx Brooklyn Manhattan Queens Staten Island
Modificar el comportamiento de Distinct
El método distinct() acepta parámetros opcionales, que representan opciones que se pueden usar para configurar la operación. Si no se especifica ninguna opción, el controlador no personaliza la operación.
La siguiente tabla describe las opciones que puedes configurar para personalizar distinct():
Propiedad | Descripción |
|---|---|
| A query filter that specifies the documents to retrieve distinct
values from. |
| An instance of ClientSession. |
| A comment to attach to the operation. |
| The maximum amount of time to allow the operation to run, in
milliseconds. |
| An instance of Collation. |
El siguiente ejemplo recupera los valores distintos del campo name para todos los documentos cuyo valor de campo borough es "Bronx" y cuyo valor de campo cuisine es "Pizza". También utiliza la opción comment para añadir un comentario a la operación. Seleccione la pestaña Synchronous o Asynchronous para ver el código correspondiente:
results = restaurants.distinct("name", { "borough": "Bronx", "cuisine": "Pizza" }, comment="Bronx pizza restaurants" )
$1.25 Pizza 18 East Gunhill Pizza 2 Bros Aenos Pizza Alitalia Pizza Restaurant ...
results = await restaurants.distinct("name", { "borough": "Bronx", "cuisine": "Pizza" }, comment="Bronx pizza restaurants" )
$1.25 Pizza 18 East Gunhill Pizza 2 Bros Aenos Pizza Alitalia Pizza Restaurant ...
Documentación de la API
Para aprender más sobre cualquiera de los métodos o tipos analizados en esta guía, consulta la siguiente documentación de API: