Operações de Escrita
Nesta página
- Visão geral
- Modelo de amostra
- Insira documentos
- Inserir um Documento Exemplos
- Exemplo de inserção de vários documentos
- Modificar documentos
- Exemplos de atualizar um documento
- Exemplo de atualização de vários documentos
- Atualizar ou inserir em uma única operação
- Exemplo de upsert
- Atualizar Matrizes em um Documento
- Adicionar valores a um exemplo de array
- Exemplo de remoção de valores de um array
- Atualizar o valor de um exemplo de elemento de array
- Exclua documentos
- Exemplos de exclusão de documento
- Exemplos de exclusão de vários documentos
Visão geral
Neste guia, você pode aprender como usar o Laravel MongoDB para executar operações de escrita em suas coleções MongoDB. As operações de gravação incluem inserir, atualizar e excluir dados com base em critérios especificados.
Este guia mostra como executar as seguintes tarefas:
Modelo de amostra
As operações de gravação neste guia referenciam a seguinte classe de modelo Eloquent :
namespace App\Models; use MongoDB\Laravel\Eloquent\Model; class Concert extends Model { protected $connection = 'mongodb'; protected $fillable = ['performer', 'venue', 'genres', 'ticketsSold', 'performanceDate']; protected $casts = ['performanceDate' => 'datetime']; }
Dica
O atributo $fillable
permite que você use a atribuição em massa do Laravel para operações de inserção. Para saber mais sobre a atribuição em massa, consulte Personalizar Atribuição de Massa na documentação da Classe de Modelo Eloquent.
O atributo $casts
instrui o Laravel a converter atributos em tipos de dados comuns. Para saber mais, consulte Fundição de Atributo na documentação do Laravel.
Insira documentos
Nesta seção, você aprenderá como inserir documentos nas coleções do MongoDB a partir do seu aplicativo Laravel usando o pacote Laravel MongoDB.
Ao inserir os documentos, certifique-se de que os dados não violem nenhum índice exclusivo da coleta. Ao inserir o primeiro documento de uma collection ou criar uma nova collection, o MongoDB cria automaticamente um índice único no campo _id
.
Para obter mais informações sobre como criar índices nas coleções do MongoDB usando o construtor de esquemas Laravel, consulte a seção Gerenciar índices da documentação do Construtor de esquemas.
Para saber mais sobre os modelos Eloquent no Laravel MongoDB, consulte a seção Modelos Eloquent .
Inserir um Documento Exemplos
Estes exemplos mostram como utilizar o método save()
Eloquent para inserir uma instância de um modelo Concert
como um documento MongoDB.
Quando o método save()
for bem-sucedido, você poderá acessar a instância do modelo na qual chamou o método.
Se a operação falhar, a instância do modelo receberá null
.
Este código de exemplo executa as seguintes ações:
Cria uma nova instância do modelo
Concert
Atribui valores de string aos campos
performer
evenue
Atribui uma array de strings ao campo
genre
Atribui um número ao campo
ticketsSold
Atribui uma data ao campo
performanceDate
usando o pacoteCarbon
Insere o documento chamando o método
save()
$concert = new Concert(); $concert->performer = 'Mitsuko Uchida'; $concert->venue = 'Carnegie Hall'; $concert->genres = ['classical']; $concert->ticketsSold = 2121; $concert->performanceDate = Carbon::create(2024, 4, 1, 20, 0, 0, 'EST'); $concert->save();
Você pode recuperar o valor _id
do documento inserido acessando o membro id
do modelo, como mostrado no seguinte exemplo de código:
$insertedId = $concert->id;
Se você ativar a atribuição em massa definindo os atributos $fillable
ou $guarded
, poderá usar o método create()
do modelo Eloquent para executar a inserção em uma única chamada, conforme mostrado no exemplo a seguir:
$insertResult = Concert::create([ 'performer' => 'The Rolling Stones', 'venue' => 'Soldier Field', 'genres' => [ 'rock', 'pop', 'blues' ], 'ticketsSold' => 59527, 'performanceDate' => Carbon::create(2024, 6, 30, 20, 0, 0, 'CDT'), ]);
Para saber mais sobre a extensão da do PHP API Cloud , consulte o Charts Github Repositório .
Exemplo de inserção de vários documentos
Este exemplo mostra como utilizar o método insert()
Eloquent para inserir múltiplas instâncias de um modelo Concert
como documentos MongoDB . Esse método de inserção em massa reduz o número de chamadas que seu aplicação precisa fazer para salvar os documentos.
Quando o método insert()
é bem-sucedido, ele retorna o valor 1
.
Se falhar, lança uma exceção.
O código de exemplo salva vários modelos em uma única chamada, passando-os como uma array para o método insert()
:
Observação
Este exemplo envolve as datas no MongoDB\BSON\UTCDateTime classe para convertê-lo em um tipo que o MongoDB possa serializar porque o Laravel ignora a conversão de atributos em operações de inserção em massa.
$data = [ [ 'performer' => 'Brad Mehldau', 'venue' => 'Philharmonie de Paris', 'genres' => [ 'jazz', 'post-bop' ], 'ticketsSold' => 5745, 'performanceDate' => new UTCDateTime(Carbon::create(2025, 2, 12, 20, 0, 0, 'CET')), ], [ 'performer' => 'Billy Joel', 'venue' => 'Madison Square Garden', 'genres' => [ 'rock', 'soft rock', 'pop rock' ], 'ticketsSold' => 12852, 'performanceDate' => new UTCDateTime(Carbon::create(2025, 2, 12, 20, 0, 0, 'CET')), ], ]; Concert::insert($data);
Modificar documentos
Nesta seção, você pode aprender como modificar documentos em sua coleção MongoDB a partir do seu aplicativo Laravel. Use operações de atualização para modificar documentos existentes ou inserir um documento se nenhum corresponder aos critérios do Atlas Search .
Você pode persistir alterações em uma instância de um modelo Eloquent ou usar a sintaxe fluente do Eloquent para encadear uma operação de atualização em métodos que retornam um objeto de coleção Laravel.
Esta seção fornece exemplos das seguintes operações de atualização:
Exemplos de atualizar um documento
Você pode atualizar um documento das seguintes maneiras:
Modifique uma instância do modelo e salve as alterações chamando o método
save()
.Métodos de encadeamento para recuperar uma instância de um modelo e executar atualizações chamando o método
update()
.
O exemplo a seguir mostra como atualizar um documento modificando uma instância do modelo e chamando seu método save()
:
$concert = Concert::first(); $concert->venue = 'Manchester Arena'; $concert->ticketsSold = 9543; $concert->save();
Quando o método save()
for bem-sucedido, a instância do modelo na qual você chamou o método conterá os valores atualizados.
Se a operação falhar, o Laravel MongoDB atribuirá à instância do modelo um valor null
.
O exemplo a seguir mostra como atualizar um documento encadeando métodos para recuperar e atualizar o primeiro documento correspondente:
$concert = Concert::where(['performer' => 'Brad Mehldau']) ->orderBy('_id') ->first() ->update(['venue' => 'Manchester Arena', 'ticketsSold' => 9543]);
Observação
A chamada orderBy()
classifica os resultados pelo campo _id
para garantir uma ordem de classificação consistente. Para saber mais sobre classificação no MongoDB, consulte a entrada do glossário de ordem natural no manual do servidor MongoDB.
Quando o método update()
é bem-sucedido, a operação retorna o número de documentos atualizados.
Se a parte de recuperação da chamada não corresponder a nenhum documento, o Laravel MongoDB retornará o seguinte erro:
Error: Call to a member function update() on null
Exemplo de atualização de vários documentos
Para realizar uma atualização em um ou mais documentos, encadeie o método update()
aos resultados de um método que recupera os documentos como um objeto de coleção do Laravel, como where()
.
O exemplo a seguir mostra como encadear chamadas para recuperar documentos correspondentes e atualizá-los:
Concert::whereIn('venue', ['Philharmonie de Paris', 'Soldier Field']) ->update(['venue' => 'Concertgebouw', 'ticketsSold' => 0]);
Quando o método update()
é bem-sucedido, a operação retorna o número de documentos atualizados.
Se a parte de recuperação da chamada não corresponder a nenhum documento na coleção, o Laravel MongoDB retornará o seguinte erro:
Error: Call to a member function update() on null
Atualizar ou inserir em uma única operação
Uma operação upsert permite realizar uma atualização ou inserir em uma única operação. Essa operação simplifica a tarefa de atualizar um documento ou inserir um se ele não existir.
Para especificar um upsert em um update()
método , defina a upsert
opção true
como , conforme mostrado no exemplo de código a seguir:
YourModel::where(/* match criteria */) ->update( [/* update data */], ['upsert' => true]);
Quando o método update()
está encadeado a uma query, ele executa uma das seguintes ações:
Se a query corresponder aos documentos, o método
update()
modificará os documentos correspondentes.Se a query corresponder a zero documentos, o método
update()
inserirá um documento que conterá os dados de atualização e os dados dos critérios de correspondência de igualdade.
Exemplo de upsert
Este exemplo mostra como passar a opção upsert
para o método update()
para executar uma atualização ou inserir em uma única operação. Clique no botão VIEW OUTPUT para ver o documento de exemplo inserido quando não houver documentos correspondentes:
Concert::where(['performer' => 'Jon Batiste', 'venue' => 'Radio City Music Hall']) ->update( ['genres' => ['R&B', 'soul'], 'ticketsSold' => 4000], ['upsert' => true], );
Atualizar Matrizes em um Documento
Nesta seção, você pode ver exemplos das seguintes operações que atualizam valores de array em um documento MongoDB:
Estes exemplos modificam o documento de amostra criado pela seguinte operação de inserção:
Concert::create([ 'performer' => 'Mitsuko Uchida', 'genres' => ['classical', 'dance-pop'], ]);
Adicionar valores a um exemplo de array
Esta seção mostra como usar o método push()
para adicionar valores a uma array em um documento MongoDB. Você pode passar um ou mais valores para adicionar e definir o parâmetro opcional unique
como true
para ignorar a adição de valores duplicados na array. O seguinte exemplo de código mostra a estrutura de uma chamada de método do push()
:
YourModel::where(<match criteria>) ->push( <field name>, [<values>], // array or single value to add unique: true); // whether to skip existing values
O exemplo a seguir mostra como adicionar o valor "baroque"
ao campo de array genres
de um documento correspondente. Clique no botão VIEW OUTPUT para ver o documento atualizado:
Concert::where('performer', 'Mitsuko Uchida') ->push( 'genres', ['baroque'], );
Exemplo de remoção de valores de um array
Esta seção mostra como usar o método pull()
para remover valores de uma array em um documento MongoDB. Você pode passar um ou mais valores para remover da array. O seguinte exemplo de código mostra a estrutura de uma chamada de método do pull()
:
YourModel::where(<match criteria>) ->pull( <field name>, [<values>]); // array or single value to remove
O exemplo seguinte mostra como remover os valores de array "classical"
e "dance-pop"
do campo de array genres
. Clique no botão VIEW OUTPUT para ver o documento atualizado:
Concert::where('performer', 'Mitsuko Uchida') ->pull( 'genres', ['dance-pop', 'classical'], );
Atualizar o valor de um exemplo de elemento de array
Esta seção mostra como usar o operador posicional $
para atualizar elementos de array específicos em um documento do MongoDB. O operador $
representa o primeiro elemento de array que corresponde à query. O seguinte exemplo de código mostra a estrutura de uma chamada de atualização do operador posicional em um único documento correspondente:
Observação
Atualmente, o Laravel MongoDB oferece esta operação apenas na fase DB
e não no Eloquent ORM.
DB::connection('mongodb') ->getCollection(<collection name>) ->updateOne( <match criteria>, ['$set' => ['<array field>.$' => <replacement value>]]);
O exemplo seguinte mostra como substituir o valor de array "dance-pop"
por "contemporary"
no campo de array genres
. Clique no botão VIEW OUTPUT para ver o documento atualizado:
$match = ['performer' => 'Mitsuko Uchida', 'genres' => 'dance-pop']; $update = ['$set' => ['genres.$' => 'contemporary']]; DB::connection('mongodb') ->getCollection('concerts') ->updateOne($match, $update);
Para saber mais sobre operadores de atualização de array, consulte Operadores de atualização de array no manual do servidor MongoDB.
Exclua documentos
Nesta seção, você pode aprender como excluir documentos de uma coleção MongoDB usando Laravel MongoDB. Use as operações de exclusão para remover dados do seu banco de banco de dados MongoDB .
Esta seção fornece exemplos das seguintes operações de exclusão:
Para saber mais sobre os recursos do Laravel disponíveis no Laravel MongoDB que modificam o comportamento de exclusão, consulte as seguintes seções:
Exclusão suave, que permite marcar documentos como excluídos em vez de removê-los do banco de dados
Remoção, que permite definir condições que qualificam um documento para exclusão automática
Exemplos de exclusão de documento
Você pode excluir um documento das seguintes maneiras:
Ligue para o método
$model->delete()
em uma instância do modelo.Chame o método
Model::destroy($id)
no modelo, passando o ID do documento a ser excluído.Métodos de cadeia para recuperar e excluir uma instância de um modelo chamando o método
delete()
.
O exemplo a seguir mostra como excluir um documento chamando $model->delete()
em uma instância do modelo:
$concert = Concert::first(); $concert->delete();
Quando o método delete()
é bem-sucedido, a operação retorna o número de documentos excluídos.
Se a parte de recuperação da chamada não corresponder a nenhum documento na coleção, a operação retornará 0
.
O exemplo a seguir mostra como excluir um documento passando o valor de seu ID para o método Model::destroy($id)
:
$id = 'MSG-0212252000'; Concert::destroy($id);
Quando o método destroy()
é bem-sucedido, ele retorna o número de documentos excluídos.
Se o valor de ID não corresponder a nenhum documento, o método destroy()
retornará 0
.
O exemplo a seguir mostra como encadear chamadas para recuperar o primeiro documento correspondente e excluí-lo:
Concert::where('venue', 'Carnegie Hall') ->limit(1) ->delete();
Observação
A chamada orderBy()
classifica os resultados pelo campo _id
para garantir uma ordem de classificação consistente. Para saber mais sobre classificação no MongoDB, consulte a entrada do glossário de ordem natural no manual do servidor MongoDB.
Quando o método delete()
é bem-sucedido, ele retorna o número de documentos excluídos.
Se o método where()
não corresponder a nenhum documento, o método delete()
retornará 0
.
Exemplos de exclusão de vários documentos
Você pode excluir vários documentos das seguintes maneiras:
Chame o método
Model::destroy($ids)
, passando uma lista das IDs dos documentos ou instâncias de modelo a serem excluídas.Métodos de cadeia para recuperar um objeto de coleção do Laravel que faz referência a vários objetos e excluí-los chamando o método
delete()
.
O exemplo a seguir mostra como excluir um documento passando uma array de valores de ID , representados por $ids
, para o método destroy()
:
$ids = [3, 5, 7, 9]; Concert::destroy($ids);
Dica
O desempenho do método destroy()
é prejudicado quando são passadas listas grandes. Para melhor desempenho, use Model::whereIn('id', $ids)->delete()
em vez disso.
Quando o método destroy()
é bem-sucedido, ele retorna o número de documentos excluídos.
Se os valores de ID não corresponderem a nenhum documento, o método destroy()
retornará 0
.
O exemplo a seguir mostra como encadear chamadas para recuperar documentos correspondentes e excluí-los:
Concert::where('ticketsSold', '>', 7500) ->delete();
Quando o método delete()
é bem-sucedido, ele retorna o número de documentos excluídos.
Se o método where()
não corresponder a nenhum documento, o método delete()
retornará 0
.