DEV Community

Cover image for Curtas sobre a DP-900: Conceitos básicos de dados | Parte 2
Mateus Lemos
Mateus Lemos

Posted on • Updated on

Curtas sobre a DP-900: Conceitos básicos de dados | Parte 2

Fala moçada, beleza?!

No artigo passado falamos um pouco sobre os dados, seus tipos e seus armazenamentos. No artigo de hoje, a ideia é explorar um pouco sobre processamento transacional. Então se prepara, pega um café, ou suco, ou água, se tiver um biscoitinho aí também, é bem legal para acompanhar 🤣. Vamos nessa!

Quando falamos de transação, você pode ter algumas lembranças; eu mesmo quando ouço essa palavra me bate logo na mente transações financeiras (quem quer dinheiro??? procura o Silvio Santos 🤣).

Image description

É interessante a natureza de uma transação financeira, supondo que você queira transferir um valor de sua conta para a conta de uma outra pessoa, você não vai querer que o valor saia de sua conta e se perca por exemplo, sendo feito somente o débito do valor e nada mais. Você também acharia estranho que um valor fosse enviado para a outra pessoa, porém, sem ser debitado de sua conta. Isso é um exemplo onde falei de passos muito simplistas por sinal, mas podemos perceber que para que tudo dê certo, tem pelo menos dois passos mencionados:

  1. O primeiro é o débito em sua conta.
  2. O segundo o crédito na conta da outra pessoa.

Exemplo de transações no dia a dia

Essas operações descritas acima, não serão passos isolados, eles vão representar uma unidade de trabalho; o que quero dizer é que, o ato de transferir só é válido se ocorrer, minimamente (e desconsiderando qualquer outro processo que seja feito), com sucesso esses dois passos. Uma transação de dados é algo similar. Na documentação da Microsoft fala justamente esse termo, uma unidade de trabalho. Uma outra forma de pensar, é que uma transação seria um conjunto de passos que devem ser executados sobre os dados, onde essa operação será enxergada como um único processo. Caso dê erro em um dos passos, todos os outros passos devem ser desfeitos.

Esse modelo transacional faz parte dos bancos relacionais, apesar de vermos atualmente muitas pessoas falando sobre bancos NoSQL, acredito que o modelo relacional ainda domina o cenário em aplicações empresariais, que de certa forma, são beneficiadas por essa forma de trabalho. Talvez você tenha visto nas regras de negócio de sua empresa, se você não trabalha ainda na área continue conosco que você vai ser beneficiado também, operações que devem ocorrer em conjunto no banco, talvez atualizar tabelas diferentes, e que nesse cenário tem que ser “tudo ou nada”.

Então, um modelo transacional vai suportar isso aí; além disso, um sistema transacional foi feito também para suportar um alto volume de operações e velocidade de acesso dos dados, a ideia é que os dados sejam otimizados para operações de gravação e consulta. O trabalho realizado pelo sistema transacional é conhecido também como OLTP, que na prática significa “Processamento de Transações Online”. Em soluções OLTP existem operações que são muito conhecidas pelos desenvolvedores, os famosos CRUD’s (Create, Read, Update e Delete), para quem ainda não está familiarizado com a área, de forma bem rápida, os CRUD’s são operações de criação, leitura, atualização e exclusão dos dados em um banco de dados. Essas operações geralmente são realizadas de forma transacional para poder manter a integridade dos dados.

ACID

Outro assunto importante dentro dessa parte de sistema transacional, e que é pedido na DP-900, é o entendimento sobre ACID. Você quis dizer ácido Mateus? Não, ACID mesmo, ele é um acrônimo para Atomicidade, Consistência, Isolamento e Durabilidade (isso trazendo para nosso pt-br! Hahaha). Essa sigla representa características de uma transação em um banco de dados. Vamos falar um pouco mais sobre eles:

Atomicidade

Entenda esse conceito como algo único, ou é tudo ou nada como falei mais acima, no caso, se você tiver um conjunto de operações em uma transação, ele será enxergado como algo atômico, ou seja, se uma parte do processo falhar, vai falhar a operação inteira.

Consistência

Os dados antes e após passarem por uma transação devem estar consistentes, não devem possuir anomalias causadas por erros em transações, é uma propriedade que se refere ao estado dos dados.

Isolamento

Uma transação é isolada da outra, ou seja, uma não vai interferir na outra, é tipo uma criança egoísta, se ela tá brincando com um brinquedo, outra não deve interferir.

Durabilidade

A ideia dessa propriedade é que, uma vez persistido as operações sobre os dados, caso o banco fique fora (ah Mateus, ele gosta de passear né?! 🤣) por algum motivo, ao voltar o serviço, os dados continuam lá sem problemas.

Image description

Considerações finais

E assim encerramos o assunto sobre soluções transacionais da certificação da DP-900, no próximo artigo vamos falar sobre soluções analíticas. Se você chegou até aqui, parabéns e obrigado, caso pulou para a última parte ou se está lendo só esse trecho, tem um segredo em alguma parte do texto, quando ler e descobrir me conta! Bom, até a próxima moçada! 😃

Agradecimentos

Não posso encerrar esse texto sem agradecer aos revisores que abrilhantaram e colaboraram ativamente com esse artigo. Agradeço a revisão do Renan e também a revisão e imagens do Ono. Muito obrigado, vocês são demais! 😃

Top comments (4)

Collapse
 
barbosarenan profile image
Renan Barbosa

Receba! Já estou mais preparado para tirar essa certificação em breve após esse conteúdo. Seguimos estudando.

Collapse
 
mateuslemos profile image
Mateus Lemos

É isso ae Renan, vamos juntos! 😀🚀🚀🚀🚀🚀

Collapse
 
kless1 profile image
Kless1

👏👏

Collapse
 
mateuslemos profile image
Mateus Lemos

😀😀🚀🚀🚀