Overview
En esta guía, puedes aprender cómo usar el controlador de Ruby para agregar documentos a una colección MongoDB mediante la realización de operaciones de inserción.
Una operación de inserción inserta uno o más documentos en una colección de MongoDB. Puedes realizar una operación de inserción mediante los siguientes métodos:
insert_onepara insertar un solo documentoinsert_manypara insertar uno o más documentos
Datos de muestra
Los ejemplos de esta guía usan la colección restaurants en la base de datos sample_restaurants de la Conjuntos de datos de muestra de Atlas. Para acceder a esta colección desde su aplicación Ruby, cree un objeto Mongo::Client que se conecte a un clúster Atlas y asigne los siguientes valores a las variables database y collection:
database = client.use('sample_restaurants') collection = database[:restaurants]
Para aprender cómo crear un clúster gratuito de MongoDB Atlas y cargar los conjuntos de datos de ejemplo, consulta la guía MongoDB Get Started.
El campo _id
En una colección de MongoDB, cada documento debe contener un campo _id con un valor de campo único.
MongoDB permite gestionar este campo de dos formas:
Establece el campo
_idpara cada documento tú mismo, asegurándote de que cada valor sea único.Permite que el driver genere automáticamente valores únicos de
BSON::ObjectIdpara cada campo_iddel documento.
A menos que pueda garantizar la exclusividad, recomendamos dejar que el controlador genere automáticamente los valores de _id.
Nota
Los valores _id duplicados violan las restricciones de índice único, lo que hace que el controlador devuelva un error.
Para obtener más información sobre el campo _id, consulta la guía Índices únicos en el manual del MongoDB Server.
Para obtener más información sobre la estructura y las reglas de los documentos, consulta la guía de Documentos en el manual de MongoDB Server.
Inserta un documento
Para añadir un solo documento a una colección de MongoDB, llama al método insert_one y pasa el documento que quieres insertar.
El siguiente ejemplo inserta un documento en la colección restaurants:
document = { name: 'Neighborhood Bar & Grill', borough: 'Queens' } collection.insert_one(document)
Inserta varios documentos
Para añadir varios documentos a una colección de MongoDB, llama al método insert_many y pasa una lista de documentos que deseas insertar.
El siguiente ejemplo inserta dos documentos en la colección restaurants:
documents = [ { name: 'Metropolitan Cafe', borough: 'Queens' }, { name: 'Yankee Bistro', borough: 'Bronx' } ] collection.insert_many(documents)
Modificar el comportamiento de inserción
Puede pasar un objeto Hash como parámetro al método insert_one para configurar las opciones de inserción. Si no especifica ninguna opción, el controlador ejecuta la inserción con la configuración predeterminada.
La siguiente tabla describe las opciones que puede configurar para la insert_one operación:
Opción | Descripción |
|---|---|
| Instructs the driver whether to ignore document-level validation. For more information,
see Schema Validation in the MongoDB Server manual. Defaults to false. |
| Sets a comment to attach to the operation. For more information, see the insert command
fields guide in the MongoDB Server manual. |
| Sets the session to use for the operation. To learn more about sessions, see
Client Sessions and Causal Consistency Guarantees
in the MongoDB Server manual. |
| Sets the write concern for the operation. For more information, see the
Write Concern guide in the MongoDB Server manual. |
Puedes configurar los ajustes anteriores en el método insert_many pasando un Hash como parámetro en la llamada al método. También puedes utilizar la opción ordered para especificar el orden en el que el driver inserta documentos en MongoDB.
Ejemplo
El siguiente código utiliza el método insert_many para insertar tres nuevos documentos en una colección. Debido a que la opción bypass_document_validation está habilitada, esta operación de inserción omite la validación a nivel de documento.
documents = [ { name: 'Cloudy Day', borough: 'Brooklyn' }, { name: 'Squall or Shine', borough: 'Staten Island' } { name: 'Rose Field', borough: 'Queens' } ] options = { bypass_document_validation: true } collection.insert_many(documents, options)
Documentación de la API
Para obtener más información sobre cualquiera de los métodos mencionados en esta guía, consulta la siguiente documentación de la API: