Exploring Modern Databases in React Applications

Rate this content
Bookmark

Traditional databases often hinder React developers' workflow. New approaches, including serverless solutions, are revolutionizing data handling in React apps. This talk explores how modern database paradigms enable end-to-end type safety, create ergonomic workflows, and support rapid iteration. Learn how these next-gen databases integrate with React to simplify development and boost productivity, helping you build more efficient and performant applications.

This talk has been presented at React Advanced 2024, check out the latest edition of this React Conference.

FAQ

Branching allows developers to create a copy of a database schema for each feature branch, facilitating preview deployments and integration with platforms like GitHub and hosting solutions like Vercel.

Multimodal databases, like SurrealDB, allow storing different kinds of data (key-value, document, relational) in one database, offering flexibility in data querying and storage.

Type safety ensures that data types in the database are properly reflected in server or front-end code, reducing errors and facilitating safe data manipulation. Tools like Prisma and Drizzle provide this feature through automatic type inference.

When selecting a modern database, consider factors like scalability, AI capabilities, type safety, ease of integration, and the specific needs of your project, such as data-intensiveness or real-time requirements.

The development ecosystem has evolved with JavaScript developers writing server code, making React a full-stack framework. This change was facilitated by technologies like Node.js, Next.js with API routes, and serverless databases.

Modern database trends include serverless databases, AI-focused databases, branching, multimodal databases, and good type safety with developer experience tools like Prisma and Drizzle.

Serverless databases abstract complex tasks and offer benefits like autoscaling, full maintenance, and built-in security features. Examples include Superbase, Firebase, AWS Aurora, and PlanetScale.

Graph relational databases, like EdgeDB, simplify querying relations by combining SQL and GraphQL concepts, allowing for easier querying of data with complex relationships.

AI in databases allows for deeper searches using vector databases or vector indexes. This enables searching broader terms and is optimized in databases like Pinecone, ChromaDB, and those using PGVector extensions.

AI enhances vector databases by optimizing them for AI-specific tasks, allowing deeper and more relevant searches on unstructured data. This is achieved through databases strictly focused on AI or regular databases with added AI functionalities.

Aleksandra Sikora
Aleksandra Sikora
31 min
25 Oct, 2024

Comments

Sign in or register to post your comment.
Video Summary and Transcription
I'm going to be talking about modern databases in the React ecosystem. The development work used to be simple, with front-end and backend developers working separately. However, with the rise of Node.js and full stack frameworks like Next.js, the ecosystem has evolved. Now, front-end developers are often writing back-end code, and databases have become a crucial component. In this talk, we'll explore the modern solutions and their strengths when it comes to databases. We'll discuss the changes in the databases world and how React and other frameworks have made accessing databases easier. Serverless databases simplify the complexity of managing databases, but there are considerations like vendor lock-in and limited customization options. AI databases with vector functionality provide deeper searches on unstructured data. Multimodal databases like SurrealDB allow for different kinds of data in one storage. Tools like Prisma, Drizzle, and EdgeDB provide good type safety and ease of use. EdgeDB is a graph relational database that combines SQL and GraphQL, making querying relations easier. Database selection is not permanent, and it's important to consider user needs and stay informed about modern trends. Early adoption of cutting-edge databases comes with risks, but also full-time support. Using the best tool for the job is crucial, and trying new tricks for specific data is recommended.

1. Introduction to Modern Databases in React

Short description:

I'm going to be talking about modern databases in the React ecosystem. The development work used to be simple, with front-end and backend developers working separately. However, with the rise of Node.js and full stack frameworks like Next.js, the ecosystem has evolved. Now, front-end developers are often writing back-end code, and databases have become a crucial component. In this talk, we'll explore the modern solutions and their strengths when it comes to databases.

I'm going to be talking about modern databases in the React ecosystem. And first, a few more words about me. I do run developer experience at HDB currently. I was previously working a lot with open source at Bleach.js and also around GraphQL at The Guild and before at Hasura. You can find me on Twitter as Alexandra says. So if you have any questions or you want to talk about anything databases-related, don't hesitate to reach out. Or you can check out my personal website, alexandra.codes.

So not too long time ago, the development work was simple. So we had front-end developers in the world of UI, and we had backend developers dealing with databases, servers, and so on. And there was this wall between them. And when I wanted to build a feature, the flow was like the design team would design the application, then the backend team would design the API, then everyone would have to argue about the API, and then front-end developers would have to wait maybe a few weeks for the backend team to be done, then they can start their work. And if there are any inconsistencies, the work would start all over.

But then something interesting happened in 2009 with the development of Node.js, because suddenly JavaScript developers were able to write server code as well. And that slightly changed the ecosystem. The mean stack was very popular, so Mongo, Express, Angular, and Node. And then we also had Next.js appearing in 2016. And in 2019, Next.js introduced API routes, which made it a full stack framework. And now I also want you to take a look at some of the recent years. So in 2020, that was also a point where a lot changed in the development ecosystem. So we had Prisma beta that kind of led to development of a few tools, for example, Bit.js, where you were able to import server code directly into your client components and run it without fearing that it will leak to the browser. And then we also had a few frameworks like Redwood, T3 with trpc-remix. And in 2022, Next.js 14 announced the integration with React server components. So with all of those changes of the ecosystem changing and frameworks evolving into full stack ones, databases landscape also changed. So now that we are able to jump in and out of our servers within our front end, within our client components, we can move this network boundary as it suits us. So with that, we can now explore some of the modern solutions and their strengths when it comes to databases.

And that's especially important because front-end developers are more often writing back-end code nowadays, and React is now a full stack framework. So what is the most important component of back-end? It's a database. And that's the foundation of our application where we store our data and that data powers our features. And I'm not going to give you a recipe on how to pick the best database for your project, because that decision can be a bit more nuanced than just looking at the features. There are some decisions like relational, non-relational, OLAP versus OLTP.

2. Overview of Changes in the Databases World

Short description:

In this part, we'll discuss the changes in the databases world and how React and other frameworks have made accessing databases easier. We'll explore the challenges and solutions to setting up databases and the benefits of using solutions that simplify the process.

You see, it's hard to pronounce, so that's a lot of decisions. And those decisions should be done, like, very early, because they are costly to go back on. But instead of that, I hope to give you an overview of what you can expect in 2024 and what are some of the features that you can take into account when looking at databases. Because the truth is that, not only in the frameworks world, a lot has changed, but also in the databases world. And if you're not, like, following the databases world, it might be, like, you know, there are a few traditional ones, like Postgres or MySQL. But the truth is that we have a lot of them. Like, there are jokes that there is a new database every week. And the thing is that those traditional databases, they can't really keep up to how React or other frameworks built on top of React changed. Because a lot of things got easier. And now we can, for example, in this code with React Server Components, we can access the database directly in our client component. And that looks fun, that looks easy. But then there is a question, like, what is this DB? Where does it come from? And how to set it up? So, those decisions and solutions that make those decisions easier is something that I want to talk about. Because databases are quite hard, and there is a lot beneath the surface that we don't really need to be bothered with when we are building applications. And there are solutions that kind of take this burden away from us.

QnA

Check out more articles and videos

We constantly think of articles and videos that might spark Git people interest / skill us up or help building a stellar career

TypeScript and the Database: Who Owns the Types?
TypeScript Congress 2022TypeScript Congress 2022
27 min
TypeScript and the Database: Who Owns the Types?
Top Content
The Talk discusses the use of TypeScript and SQL together in software development. It explores different approaches, such as using an ORM like TypeORM or a schema generator like pg2ts. Query builders like connects JS and tools like PGTyped are also discussed. The benefits and trade-offs of using TypeScript and SQL are highlighted, emphasizing the importance of finding a middle ground approach.
I Would Never Use an ORM
JSNation 2023JSNation 2023
29 min
I Would Never Use an ORM
Top Content
Welcome to a talk on Object-Relational Mapping (ORM) and its potential pitfalls. The speaker discusses issues with modals and the MVC pattern, as well as the benefits of structuring code around system features instead. They introduce PlatformaticDB as a solution for easy backend development, showcasing its deployment and testing capabilities. The talk also covers integrating with Next.js, writing custom SQL queries, and the speaker's plans for future support and database compatibility.
Database Access on the Edge with Cloudflare Workers & Prisma
Node Congress 2022Node Congress 2022
31 min
Database Access on the Edge with Cloudflare Workers & Prisma
This Talk discusses database access on the edge with CloudFlare workers and the challenges of serverless platforms. It explores solutions for database access, including CloudFlare-specific solutions and using Prisma data proxy. The Prisma toolkit and demo are showcased, demonstrating how to convert an application to use a database. The process of setting up Prisma Data Platform and deploying the application to CloudFlare workers is explained. The Talk concludes with insights on database usage and the differences between serverless, CDN, and the Edge.
Bring AI-Based Search to Your Web App
JSNation 2023JSNation 2023
31 min
Bring AI-Based Search to Your Web App
The Talk discusses the use of machine learning in search engines, specifically focusing on semantic search and vector embeddings. It explores the integration of JavaScript and machine learning models, using Weaviate as an open-source vector database. The Talk demonstrates how to connect to Weaviate, query data, and perform machine learning queries. It also highlights the benefits of Weaviate, such as its superior developer experience and performance. Additionally, the Talk addresses customization options, data privacy concerns, and the varying effectiveness of different machine learning models.
Remix Persistence With DynamoDB
Remix Conf Europe 2022Remix Conf Europe 2022
41 min
Remix Persistence With DynamoDB
DynamoDB is a next-generation key-value database that is low-latency, scalable, and easy to use. It offers advantages such as local development options, a generous free tier, and fast performance. Common misconceptions about DynamoDB being expensive or hard to learn are debunked. The Talk covers topics like basic modeling, separating concerns, working with DynamoDB in Remix, and building a DynamoDB client. Overall, DynamoDB is a powerful database that integrates well with Remix and provides efficient data access patterns.
Local-First Software With ElectricSQL
React Advanced 2023React Advanced 2023
29 min
Local-First Software With ElectricSQL
Watch video: Local-First Software With ElectricSQL
Local-first software allows for instant display of data to the user, offering zero latency and offline functionality. It simplifies data synchronization and enables real-time multi-user sync. Popular tools like Facebook Messenger and Google Workspace apps have adopted this pattern. Electric SQL provides a drop-in sync layer for existing applications, combining real-time functionality with conflict-free offline capabilities. Local-first software replaces APIs and microservices with a standardized replication protocol, simplifying state management and reducing server load.

Workshops on related topic

How to Solve Real-World Problems with Remix
Remix Conf Europe 2022Remix Conf Europe 2022
195 min
How to Solve Real-World Problems with Remix
Featured Workshop
Michael Carter
Michael Carter
- Errors? How to render and log your server and client errorsa - When to return errors vs throwb - Setup logging service like Sentry, LogRocket, and Bugsnag- Forms? How to validate and handle multi-page formsa - Use zod to validate form data in your actionb - Step through multi-page forms without losing data- Stuck? How to patch bugs or missing features in Remix so you can move ona - Use patch-package to quickly fix your Remix installb - Show tool for managing multiple patches and cherry-pick open PRs- Users? How to handle multi-tenant apps with Prismaa - Determine tenant by host or by userb - Multiple database or single database/multiple schemasc - Ensures tenant data always separate from others
Relational Database Modeling for GraphQL
GraphQL Galaxy 2020GraphQL Galaxy 2020
106 min
Relational Database Modeling for GraphQL
Top Content
WorkshopFree
Adron Hall
Adron Hall
In this workshop we'll dig deeper into data modeling. We'll start with a discussion about various database types and how they map to GraphQL. Once that groundwork is laid out, the focus will shift to specific types of databases and how to build data models that work best for GraphQL within various scenarios.
Table of contentsPart 1 - Hour 1      a. Relational Database Data Modeling      b. Comparing Relational and NoSQL Databases      c. GraphQL with the Database in mindPart 2 - Hour 2      a. Designing Relational Data Models      b. Relationship, Building MultijoinsTables      c. GraphQL & Relational Data Modeling Query Complexities
Prerequisites      a. Data modeling tool. The trainer will be using dbdiagram      b. Postgres, albeit no need to install this locally, as I'll be using a Postgres Dicker image, from Docker Hub for all examples      c. Hasura
Scaling up Your Database With ReadySet
Node Congress 2023Node Congress 2023
33 min
Scaling up Your Database With ReadySet
WorkshopFree
Aspen Smith
Nick Marino
2 authors
The database can be one of the hardest parts of a web app to scale. Many projects end up using ad-hoc caching systems that are complex, error-prone, and expensive to build. What if you could drop in a ready-built caching system to enable better throughput and latency with no code changes to your application?
Join developers Aspen Smith and Nick Marino to see how you can change one line of config in your app and use ReadySet to scale up your query performance by orders of magnitude today.
Build a Full Stack React Native App with Oracle 23ai
React Summit 2024React Summit 2024
37 min
Build a Full Stack React Native App with Oracle 23ai
WorkshopFree
Doug Drechsel
Doug Drechsel
In this workshop, you will set up a local full-stack environment and create a React Native Mobile app that runs against that stack. 
Agenda:- Install Oracle 23ai Docker container- Build and run Parse Server with the new Oracle Storage Adapter - Build and run a Walking History React Native mobile app against the stack
Walking History is a React Native application that allows you to walk around New York City (or simulate that in a device emulator) and it tells you about the closest attraction or point of interest.


Building a Realtime App with Remix and Supabase
Remix Conf Europe 2022Remix Conf Europe 2022
156 min
Building a Realtime App with Remix and Supabase
Workshop
Jon Meyers
Jon Meyers
Supabase and Remix make building fullstack apps easy. In this workshop, we are going to learn how to use Supabase to implement authentication and authorization into a realtime Remix application. Join Jon Meyers as he steps through building this app from scratch and demonstrating how you can harness the power of relational databases!
Building a GraphQL-native serverless backend with Fauna
GraphQL Galaxy 2021GraphQL Galaxy 2021
143 min
Building a GraphQL-native serverless backend with Fauna
WorkshopFree
Rob Sutter
Shadid Haque
2 authors
Welcome to Fauna! This workshop helps GraphQL developers build performant applications with Fauna that scale to any size userbase. You start with the basics, using only the GraphQL playground in the Fauna dashboard, then build a complete full-stack application with Next.js, adding functionality as you go along.

In the first section, Getting started with Fauna, you learn how Fauna automatically creates queries, mutations, and other resources based on your GraphQL schema. You learn how to accomplish common tasks with GraphQL, how to use the Fauna Query Language (FQL) to perform more advanced tasks.

In the second section, Building with Fauna, you learn how Fauna automatically creates queries, mutations, and other resources based on your GraphQL schema. You learn how to accomplish common tasks with GraphQL, how to use the Fauna Query Language (FQL) to perform more advanced tasks.