Software Alternatives, Accelerators & Startups

MyBATIS VS JDBI

Compare MyBATIS VS JDBI and see what are their differences

MyBATIS logo MyBATIS

MyBatis is a top-rated SQL-based data mapping solution used by Programmers, Software Engineers, and Database Architects for developing object-oriented software applications.

JDBI logo JDBI

See this.
  • MyBATIS Landing page
    Landing page //
    2023-04-18
  • JDBI Landing page
    Landing page //
    2023-08-02

MyBATIS features and specs

  • Simplicity
    MyBatis is easier to use compared to other ORM tools because it provides a simple and direct approach to database interaction using XML or annotations, making it accessible for developers familiar with SQL.
  • Flexibility in SQL
    It allows for complete control over SQL queries, enabling developers to write complex queries and use full SQL syntax without constraints, unlike automated ORM solutions.
  • Performance
    Since developers have direct control over SQL statements, the performance can be optimized for specific use cases, potentially reducing the overhead that automated ORM solutions might introduce.
  • Mapping
    Offers robust and customizable mapping capabilities between database tables and Java classes, helping in clearly defining how data should be transformed between the system and the data layer.
  • Lazy Loading
    Supports lazy loading of related objects, which can improve performance by delaying the fetching of data until it is specifically needed.

Possible disadvantages of MyBATIS

  • Manual SQL Management
    The need to manually write and maintain SQL can be cumbersome and error-prone, especially for complex applications with large numbers of queries.
  • Lack of Automated Associations
    MyBatis does not inherently manage relationships between entities like some other ORM tools, which requires developers to handle association mappings themselves.
  • Limited Abstraction
    Compared to full ORM frameworks, MyBatis offers less abstraction over the database layer, which means developers must handle more of the database logic manually.
  • Learning Curve for XML
    While not steep, there is a learning curve involved in configuring MyBatis using XML for those who are more accustomed to purely annotation-driven configuration or other ORM tools.
  • Reduced Portability
    Because SQL is database-specific, MyBatis applications might become less portable across different database platforms when relying extensively on custom SQL.

JDBI features and specs

  • Simplicity
    JDBI provides a simple, fluent API that makes accessing relational databases in Java more streamlined and less error-prone than using plain JDBC.
  • SQL-centric Approach
    JDBI allows developers to work directly with SQL, offering the flexibility to use any SQL feature without abstraction limitations.
  • Ease of Integration
    JDBI is easy to integrate into existing projects and works seamlessly with various database systems.
  • Declarative Mapping
    It supports declarative and annotation-based data mapping, reducing boilerplate code when converting between database rows and Java objects.
  • Extensibility
    JDBI's plugin architecture allows developers to extend its capabilities easily with custom features or integrate with other libraries.

Possible disadvantages of JDBI

  • Limited Abstraction
    Compared to full-fledged ORM frameworks, JDBI provides less abstraction, which could be a drawback for applications requiring complex entity relationships.
  • Manual Resource Management
    Developers need to manage database connections and resources, increasing the risk of resource leaks if not handled properly.
  • Less Mature than Some ORMs
    Although reliable, JDBI may not have the maturity or widespread adoption of some older ORMs, potentially resulting in less community support.
  • Learning Curve
    For developers used to traditional ORM frameworks, learning JDBI's idiomatic ways to achieve similar tasks might require an adjustment period.

MyBATIS videos

Screencast #18: Introduction to mybatis

More videos:

  • Demo - MyBatis Intro & Demo

JDBI videos

jdbi

More videos:

  • Review - Dealing with a heckler | JDBI INVICTUS ‘19

Category Popularity

0-100% (relative to MyBATIS and JDBI)
Web Frameworks
52 52%
48% 48
Development
100 100%
0% 0
Backend Development
0 0%
100% 100
Tool
100 100%
0% 0

User comments

Share your experience with using MyBATIS and JDBI. For example, how are they different and which one is better?
Log in or Post with

Reviews

These are some of the external sources and on-site user reviews we've used to compare MyBATIS and JDBI

MyBATIS Reviews

17 Popular Java Frameworks for 2023: Pros, cons, and more
MyBatis is somewhat similar to the Hibernate framework, as both facilitate communication between the application layer and the database. However, MyBatis doesn’t map Java objects to database tables like Hibernate does — instead, it links Java methods to SQL statements. As a result, SQL is visible when you’re working with the MyBatis framework, and you still have control over...
Source: raygun.com

JDBI Reviews

We have no reviews of JDBI yet.
Be the first one to post

Social recommendations and mentions

Based on our record, JDBI seems to be a lot more popular than MyBATIS. While we know about 25 links to JDBI, we've tracked only 2 mentions of MyBATIS. We are tracking product recommendations and mentions on various public social media platforms and blogs. They can help you identify which product is more popular and what people think of it.

MyBATIS mentions (2)

  • How do you guys go about the persistence layer?
    Other tools you can look at for the data layer are MyBatis (https://mybatis.org/mybatis-3/) and JOOQ (https://www.jooq.org) they put you a little closer to the database than JPA/Hibernate. Source: about 3 years ago
  • Do most established companies use ORMs?
    While its not as well known, have you ever glanced at mybatis? https://mybatis.org/mybatis-3/. Source: over 3 years ago

JDBI mentions (25)

  • JOOQ Is Not a Replacement for Hibernate. They Solve Different Problems
    Suppose we're developing an application that allows speakers to submit their talks to a conference (for simplicity, we'll only record the talk's title). Following the Transaction Script pattern, the method for submitting a talk might look like this (using JDBI for SQL):. - Source: dev.to / 5 months ago
  • Optimize Database Performance in Ruby on Rails and ActiveRecord
    _relational_ is the key word you're missing. ORMs map _objects_ to _relations_ (i.e. tables). "Unlike ORM frameworks, MyBatis does not map Java objects to database tables but Java methods to SQL statements." https://en.wikipedia.org/wiki/MyBatis "Jdbi is not an ORM. It is a convenience library to make Java database operations simpler and more pleasant to program than raw JDBC." https://jdbi.org/ "While jOOQ is not... - Source: Hacker News / 7 months ago
  • Permazen: Language-natural persistence to KV stores
    While this may work for greenfield applications, I don't see this working well for preexisting schemas. From their getting started page: "Database fields are automatically created for any abstract getter methods", which definitely scares me away since they seem to be relying on automatic field type conversions. I prefer to manage my schemas when I can and do type and DAO conversions via mapper classes in the very... - Source: Hacker News / over 1 year ago
  • Permazen: Language-natural persistence to KV stores
    Someone else mentioned jOOQ, but personally I also rather enjoyed JDBI3: https://jdbi.org/#_introduction_to_jdbi_3 It addresses the issues with using JDBC directly (not nice ergonomics), while still letting you work with SQL directly without too many abstractions in the middle. In combination with Dropwizard, it was pretty pleasant: https://www.dropwizard.io/en/stable/manual/jdbi3.html Other than that, I actually... - Source: Hacker News / over 1 year ago
  • Is ORM still an anti-pattern?
    > I've been doing ORM on Java since Hibernate was new, and it has always sucked. Have you ever looked at something like myBatis? In particular, the XML mappers: https://mybatis.org/mybatis-3/dynamic-sql.html Looking back, I actually quite liked it - you had conditionals and ability to build queries dynamically (including snippets, doing loops etc.), while still writing mostly SQL with a bit of XML DSL around it,... - Source: Hacker News / almost 2 years ago
View more

What are some alternatives?

When comparing MyBATIS and JDBI, you can also consider the following products

Hibernate - Hibernate an open source Java persistence framework project.

Postgres.js - Postgres.js - The Fastest full featured PostgreSQL client for Node.js - porsager/postgres

Entity Framework - See Comparison of Entity Framework vs NHibernate.

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

Dapper - Dapper is a user-friendly object mapper for the .NET framework.

Sequelize - Provides access to a MySQL database by mapping database entries to objects and vice-versa.