DEV Community

Cover image for Por que Prisma?
Gabriel Alves
Gabriel Alves

Posted on

Por que Prisma?

PrismaJS é um ORM (Object-Relational Mapping) moderno e poderoso para bancos de dados SQL. Ele permite que você escreva consultas de banco de dados usando uma sintaxe amigável ao desenvolvedor, além de fornecer recursos avançados como migrações de banco de dados, geração de modelos de dados e validação de entrada. PrismaJS é amplamente utilizado em aplicativos Node.js para simplificar a interação com bancos de dados SQL.

Existem várias razões pelas quais você deve considerar o uso do PrismaJS em seus projetos:

Sintaxe amigável ao desenvolvedor: O PrismaJS fornece uma sintaxe amigável ao desenvolvedor para escrever consultas de banco de dados. Ele usa uma sintaxe declarativa que é fácil de entender e manter. Por exemplo, aqui está um exemplo de consulta usando o PrismaJS:

const users = await prisma.user.findMany({
  where: {
    age: {
      greaterThan: 18
    }
  }
});


Enter fullscreen mode Exit fullscreen mode

Segurança: O PrismaJS ajuda a prevenir ataques de injeção de SQL, pois usa consultas parametrizadas por padrão. Isso significa que os valores dos parâmetros são tratados separadamente da consulta em si, evitando a possibilidade de um atacante injetar código malicioso nas consultas.
Migrações de banco de dados: O PrismaJS possui um poderoso sistema de migração de banco de dados integrado. Isso permite que você faça alterações no esquema do banco de dados de forma controlada e versionada. Com as migrações, você pode adicionar, modificar ou excluir tabelas e colunas sem perder dados.
Geração de modelos de dados: O PrismaJS gera automaticamente modelos de dados com base no esquema do banco de dados. Isso significa que você pode interagir com o banco de dados usando objetos JavaScript em vez de escrever consultas SQL manualmente. Isso torna o código mais legível e menos propenso a erros.
Suporte a vários bancos de dados: O PrismaJS suporta vários bancos de dados SQL populares, como MySQL, PostgreSQL e SQLite. Isso permite que você escolha o banco de dados que melhor atende às necessidades do seu projeto.
Para ilustrar o uso do PrismaJS, aqui está um exemplo de como você pode criar um modelo de dados e fazer consultas usando o PrismaJS:

const { PrismaClient } = require('@prisma/client');

const prisma = new PrismaClient();

// Definindo o modelo de dados
const User = prisma.user;

// Consulta todos os usuários com idade maior que 18
async function getUsers() {
  const users = await User.findMany({
    where: {
      age: {
        greaterThan: 18
      }
    }
  });

  return users;
}

// Criando um novo usuário
async function createUser(name, age) {
  const user = await User.create({
    data: {
      name,
      age
    }
  });

  return user;
}

// Exemplo de uso
async function main() {
  const users = await getUsers();
  console.log(users);

  const newUser = await createUser('John Doe', 25);
  console.log(newUser);
}

main()
  .catch((error) => {
    console.error(error);
  })
  .finally(async () => {
    await prisma.$disconnect();
  });

Enter fullscreen mode Exit fullscreen mode

Este é apenas um exemplo básico para demonstrar o uso do PrismaJS. Você pode encontrar mais informações e exemplos detalhados na Documentação Oficial do PrismaJS e em tutoriais e artigos online sobre o assunto.

Com o PrismaJS, você pode simplificar a interação com bancos de dados SQL em seus projetos Node.js, tornando o desenvolvimento mais rápido, seguro e eficiente. Portanto, considerar o uso do PrismaJS é uma escolha inteligente para desenvolvedores que desejam aproveitar os recursos avançados de um ORM moderno.

Top comments (0)