ORM frameworks used for insert only / query only apps

后端 未结 4 1903
傲寒
傲寒 2021-01-23 13:56

I\'ve been using Hibernate for years and never have a problem with it, but just realized most of my work involved a CRUD approach, where I needed data to stay persisted and modi

4条回答
  •  情话喂你
    2021-01-23 14:45

    Disclaimer: I'm the creator of jOOQ and thus, this answer is slightly biased.

    jOOQ was designed precisely for the use case your coworkers mention. In your project, you're not doing OLTP (CRUD) but OLAP, which is a very good use case for jOOQ in many aspects. jOOQ encourages using OLAP features, such as window functions, pivot tables, recursive queries, stored procedures, arrays and unnested arrays, etc. jOOQ also supports 13 different databases with all the SQL compatibility subtleties that you want to avoid. Some examples:

    • How are LIMIT .. OFFSET / TOP .. START AT, etc clauses mapped to a database?
    • How are variables bound (with or without casting)?
    • How are built-in functions supported?
    • Do derived tables need to be wrapped in parentheses?

    All of these compatibility aspects are very well covered by Hibernate as well, though. So your question comes back down to this:

    • Do you want to use Hibernate which is not the perfect technology choice, but which you know well and thus can estimate the risks? This is the way to go if everyone on the team knows and likes Hibernate and there is little time to learn new things.

    • Or do you want to use a different framework that might be more suitable, but you do not know it well and thus cannot estimate all the risks? This might be the way to go if you're the only one in favour of Hibernate and you have the time to learn new frameworks. Other frameworks you might want to consider:

      • Spring with JdbcTemplates (which can be combined with jOOQ, btw.)
      • myBATIS, which is known to handle SQL well.

    • Or you can mix technologies and use Hibernate for simpler queries and plain SQL / jOOQ / Spring / myBATIS / etc. for more complex ones.

    • Or can you handle bulk processing and OLAP querying using stored procedures (e.g. in PL/SQL if you're using Oracle) and let the database do the work? This might be the way to go if you have a good DBA or database-specialist on your team.

    There is no right or wrong answer. But you will have to make a pragmatic decision.

提交回复
热议问题