StackShareStackShare
Follow on
StackShare

Discover and share technology stacks from companies around the world.

Follow on

© 2025 StackShare. All rights reserved.

Product

  • Stacks
  • Tools
  • Feed

Company

  • About
  • Contact

Legal

  • Privacy Policy
  • Terms of Service
  1. Stackups
  2. Application & Data
  3. Databases
  4. Orm
  5. Doctrine 2 vs Objection.js

Doctrine 2 vs Objection.js

OverviewComparisonAlternatives

Overview

Doctrine 2
Doctrine 2
Stacks284
Followers207
Votes31
Objection.js
Objection.js
Stacks38
Followers67
Votes0
GitHub Stars7.3K
Forks641

Doctrine 2 vs Objection.js: What are the differences?

  1. Entity Management: In Doctrine 2, entities are managed using EntityManagers which handle the lifecycle of entities, while in Objection.js, models are used to interact with the database.
  2. Query Language: Doctrine 2 uses DQL (Doctrine Query Language) which is similar to SQL but operates on entities and their fields, whereas Objection.js uses a fluent query builder to construct queries in JavaScript.
  3. Relationship Handling: Doctrine 2 relies on annotations or configuration files to define relationships between entities, while Objection.js uses model methods or JSON schemas for defining relationships.
  4. Data Mapping: Doctrine 2 utilizes metadata mapping for defining how entities map to database tables, columns, and relationships, whereas Objection.js uses a simple convention-based approach for mapping models to database tables.
  5. Community Support: Doctrine 2 has a larger community and wider adoption since it is a part of the Symfony ecosystem, while Objection.js is primarily used within the Node.js community.
  6. Innovation: Doctrine 2 has been around for a longer period and has evolved with new features and improvements over time, while Objection.js is relatively newer and may lack certain advanced features present in Doctrine.

In Summary, Doctrine 2 and Objection.js differ in entity management, query language, relationship handling, data mapping, community support, and innovation.

Share your Stack

Help developers discover the tools you use. Get visibility for your team's tech choices and contribute to the community's knowledge.

View Docs
CLI (Node.js)
or
Manual

Detailed Comparison

Doctrine 2
Doctrine 2
Objection.js
Objection.js

Doctrine 2 sits on top of a powerful database abstraction layer (DBAL). One of its key features is the option to write database queries in a proprietary object oriented SQL dialect called Doctrine Query Language (DQL), inspired by Hibernates HQL.

It aims to stay out of your way and make it as easy as possible to use the full power of SQL and the underlying database engine while still making the common stuff easy and enjoyable.

-
A declarative way of defining models and relationships between them; Simple and fun way to fetch, insert, update and delete objects using the full power of SQL; Powerful mechanisms for eager loading, inserting and upserting object graphs; A way to store complex documents as single rows Completely Promise based API; Easy to use transactions; Optional JSON schema validation
Statistics
GitHub Stars
-
GitHub Stars
7.3K
GitHub Forks
-
GitHub Forks
641
Stacks
284
Stacks
38
Followers
207
Followers
67
Votes
31
Votes
0
Pros & Cons
Pros
  • 14
    Great abstraction, easy to use, good docs
  • 10
    Object-Oriented
  • 7
    Easy setup
No community feedback yet
Integrations
PHP
PHP
MySQL
MySQL
Node.js
Node.js
PostgreSQL
PostgreSQL
SQLite
SQLite

What are some alternatives to Doctrine 2, Objection.js?

Sequelize

Sequelize

Sequelize is a promise-based ORM for Node.js and io.js. It supports the dialects PostgreSQL, MySQL, MariaDB, SQLite and MSSQL and features solid transaction support, relations, read replication and more.

Prisma

Prisma

Prisma is an open-source database toolkit. It replaces traditional ORMs and makes database access easy with an auto-generated query builder for TypeScript & Node.js.

Hibernate

Hibernate

Hibernate is a suite of open source projects around domain models. The flagship project is Hibernate ORM, the Object Relational Mapper.

MikroORM

MikroORM

TypeScript ORM for Node.js based on Data Mapper, Unit of Work and Identity Map patterns. Supports MongoDB, MySQL, MariaDB, PostgreSQL and SQLite databases.

Entity Framework

Entity Framework

It is an object-relational mapper that enables .NET developers to work with relational data using domain-specific objects. It eliminates the need for most of the data-access code that developers usually need to write.

peewee

peewee

A small, expressive orm, written in python (2.6+, 3.2+), with built-in support for sqlite, mysql and postgresql and special extensions like hstore.

MyBatis

MyBatis

It is a first class persistence framework with support for custom SQL, stored procedures and advanced mappings. It eliminates almost all of the JDBC code and manual setting of parameters and retrieval of results. It can use simple XML or Annotations for configuration and map primitives, Map interfaces and Java POJOs (Plain Old Java Objects) to database records.

Entity Framework Core

Entity Framework Core

It is a lightweight, extensible, open source and cross-platform version of the popular Entity Framework data access technology. It can serve as an object-relational mapper (O/RM), enabling .NET developers to work with a database using .NET objects, and eliminating the need for most of the data-access code they usually need to write.

SQLAlchemy

SQLAlchemy

SQLAlchemy is the Python SQL toolkit and Object Relational Mapper that gives application developers the full power and flexibility of SQL.

Dapper

Dapper

It is an object-relational mapping product for the Microsoft.NET platform: it provides a framework for mapping an object-oriented domain model to a traditional relational database.

Related Comparisons

Bootstrap
Materialize

Bootstrap vs Materialize

Laravel
Django

Django vs Laravel vs Node.js

Bootstrap
Foundation

Bootstrap vs Foundation vs Material UI

Node.js
Spring Boot

Node.js vs Spring-Boot

Liquibase
Flyway

Flyway vs Liquibase