Logo

dev-resources.site

for different kinds of informations.

Seeking a Type-Safe Ruby on Rails in TypeScript, I Started Developing an ORM

Published at
6/11/2024
Categories
typescript
rails
orm
opensource
Author
koyopro
Categories
4 categories in total
typescript
open
rails
open
orm
open
opensource
open
Author
7 person written this
koyopro
open
Seeking a Type-Safe Ruby on Rails in TypeScript, I Started Developing an ORM

I am developing an ORM library for TypeScript called Accel Record. Recently, I published an article introducing this library, titled Introduction to "Accel Record": A TypeScript ORM Using the Active Record Pattern.

Next, I would like to explain why I decided to develop a new ORM for TypeScript.

Initial Motivation

As someone who uses Ruby on Rails for server-side development and TypeScript for front-end development, I often find myself thinking the following:

  • I want a framework for TypeScript with development efficiency comparable to Ruby on Rails.

This desire stems from wanting to use TypeScript for server-side development as well. The reasons are mainly as follows:

  • I want to develop the server-side with type safety.
  • I want to develop both the front-end and back-end in the same language to reduce context switching and learning costs.

This thought process seems common, and in fact, there are cases where TypeScript is adopted for server-side development for these reasons.

What Kind of Framework Do I Want?

So, what does a framework with development efficiency comparable to Ruby on Rails look like?

The requirements may vary from person to person, but in my case, I thought as follows:

  • It should be able to implement functionalities for common use cases in web application development with minimal code.

More specifically, I am looking for the following elements:

  • Based on developing MPA with SSR (not SPA)
  • Able to implement CRUD functions for RDB with minimal code
  • A framework that covers the MVC domain on the server-side

If such a framework existed, I believe server-side development with TypeScript could be as efficient as, if not more efficient than, using Ruby on Rails.

Existing Frameworks Were Not Satisfactory

I investigated whether a framework meeting the above requirements already existed.
The conclusion I reached was that there might not be a TypeScript framework that offers functionalities for server-side processes as efficiently and with as little code as Rails.
In general terms, existing TypeScript frameworks seem to focus more on routing and enhancing front-end/back-end integration. While they are rich in features related to View and Controller (in MVC terms), the Model part seems weaker compared to Rails.

Do We Need an ORM Like Active Record?

In Rails, the ORM handling the Model role is Active Record.
Of course, TypeScript also has ORMs, but Rails’ Active Record is more than just an ORM. It provides various functionalities related to the corresponding domain model, not just operations on DB records.

Rails is characterized by its ability to implement common functionalities with minimal code. This is possible because the model classes provided by Active Record have many features. They are tightly integrated with other parts like routing and controllers, resulting in high development efficiency.

From this perspective, I thought that to achieve the goal, TypeScript needs a highly functional ORM similar to Rails’ Active Record.

What Elements Should the ORM Have?

To provide an efficient development experience in TypeScript similar to Rails, I thought the ORM should have the following elements:

1. Active Record Pattern

It should adopt the Active Record pattern. This is because I want one class to handle not only operations on DB records but also features related to the corresponding domain model.
For instance, with an ORM adopting the Table Gateway pattern, the retrieved records are plain objects, making it difficult to attach methods related to the model.
Additionally, an Active Record pattern ORM would make it easier to integrate with features like routing and View as done in Rails.

2. Type Safety

Leveraging the advantages of TypeScript, the operations and query interface of the ORM should be type-safe.
The initial motivation was to develop the server-side with type safety, so sufficient type support is expected.

No Existing ORM Met the Requirements

Given the above considerations, I investigated existing ORMs but could not find one that was type-safe and adopted the Active Record pattern.

For example, the increasingly popular Prisma has high type safety but adopts the Table Gateway pattern.
The closest fit was TypeORM, which uses the Active Record pattern, but its type support is weaker compared to recent ORMs, and its release frequency has been low recently.

I Decided to Try Developing an ORM

Based on the above, I decided to start developing a type-safe ORM in TypeScript that adopts the Active Record pattern.
I wanted to try developing it to see if it was feasible and identify any potential challenges.

The subsequent development process will be detailed in another article, but ultimately, I published the new ORM as Accel Record.

Conclusion

In this article, I outlined why I decided to develop a new ORM for TypeScript.

The initial motivation was the desire for a framework in TypeScript with development efficiency comparable to Ruby on Rails. As I continued researching existing libraries, I realized the need for a type-safe ORM in TypeScript adopting the Active Record pattern.

Thus, I started development, and eventually released the library. To see what kind of ORM it has become, please check out Introduction to "Accel Record": A TypeScript ORM Using the Active Record Pattern and the README.

orm Article's
30 articles in total
Favicon
Let's take a quick look at Drizzle ORM
Favicon
Prisma 101 baby.
Favicon
The Step-by-Step Process of Online Reputation Repair for Personal and Business Profiles
Favicon
The Best Strategies for Removing Negative News Articles from Search Engines
Favicon
Trysil - Multi-tenat API REST
Favicon
Typing Prisma Json Fields? Yes, You Can!
Favicon
What is ORM
Favicon
Top 5 ORM Services to Safeguard Your Online Reputation in 2024
Favicon
Gorm Pagination With Ease
Favicon
Introdução ao ORM do Django: Exercícios Práticos
Favicon
Explorando ORM: Facilitando o Desenvolvimento com Bancos de Dados
Favicon
Techniques for Synchronous DB Access in TypeScript
Favicon
Why We Adopted a Synchronous API for the New TypeScript ORM
Favicon
Data Access with Dapper: A Lightweight ORM for .NET Apps
Favicon
Writing code like this improves efficiency by 100 times compared to directly using MyBatis
Favicon
The Power of Less: Streamlining Dependencies with Remult
Favicon
Seeking a Type-Safe Ruby on Rails in TypeScript, I Started Developing an ORM
Favicon
TypeORM: O ORM que Você Precisa Conhecer para Trabalhar com Node.js e TypeScript
Favicon
SQL generation: Golang's builder pattern vs Clojure's persistent map
Favicon
How to Setting Default UUID for User Model in Peewee
Favicon
Introduction to "Accel Record": A TypeScript ORM Using the Active Record Pattern
Favicon
Difference Between ORM and ODM
Favicon
How to add update, and delete data in peewee Database Python
Favicon
Most popular Postgres ORMs
Favicon
Introducing Stalactite ORM
Favicon
Advanced Django ORM Features (Q-Objects, F-Expressions, Aggregations and Annotations)
Favicon
Less Code (-75%) & More Power (💪) with Remult
Favicon
A Software Engineer's Tips and Tricks #1: Drizzle
Favicon
Asgard saviour: Neurelo
Favicon
Prisma vs. Drizzle: A Comprehensive Guide for Your NextJS Project

Featured ones: