Skip to content

Using Prisma to Bridge JavaScript Devs to Databases with Elegance

Updated: at 02:12 PM

Using Prisma to Bridge JavaScript Devs to Databases with Elegance

Dive into Prisma’s influential role in simplifying data access for JavaScript developers and shed light on some common misconceptions.


Prisma’s Role in Modern Web Development

In the myriad of tools available for web developers, Prisma stands out as a paradigm shift. It’s not just a database toolkit but a bridge that converts intricate database dynamics into concepts every JavaScript developer is familiar with. With Prisma, data becomes more than mere rows and columns—it’s about objects, properties, and relationships.


Deciphering Joins with Prisma

The debate on Prisma’s handling of joins is rife online. While it’s essential to recognize that Prisma thrives on clear database structures, it doesn’t merely replace joins with a string of SQL statements.

SQLite (Relational Database) Example:

CREATE TABLE users (id INTEGER PRIMARY KEY, name TEXT);
CREATE TABLE orders (id INTEGER PRIMARY KEY, total INTEGER, user_id INTEGER, FOREIGN KEY(user_id) REFERENCES users(id));

MongoDB (NoSQL Database) Example:

{
  "users": {
    "_id": ObjectId("some_id"),
    "name": "John Doe",
    "orders": [{
      "_id": ObjectId("another_id"),
      "total": 100
    }]
  }
}

When your structures are well-defined, extracting data becomes intuitive with Prisma:

const userWithOrders = await prisma.user.findUnique({
  where: { id: userId },
  include: { orders: true }
});

However, for databases lacking clarity in relationships, Prisma’s performance can be a tad unpredictable.


Raw SQL’s Power in Prisma

For those peculiar database setups, Prisma offers a potent solution: raw SQL queries via prisma.$executeRaw. This feature allows developers to harness the specificity of SQL without forgoing Prisma’s benefits.

const data = await prisma.$executeRaw`
  SELECT users.name, orders.total
  FROM users
  JOIN orders ON users.u_id = orders.user_ref
  WHERE users.id = ${userId}
`;

Utilizing template literals ensures you maintain the typesafety that’s core to a reliable application.


Parting Words

Navigating the web development landscape requires tools that adapt to our needs. Prisma, with its flexibility and intuitive design, certainly fits the bill. However, it’s crucial to use it wisely, acknowledging its strengths and understanding when to diverge.

Check out the ORM (Object Relational Mapper) PRISMA. The database access method I use in all my projects