Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

What ORMs work well with Scala? [closed]

I'm about to write a Scala command-line application that relies on a MySQL database. I've been looking around for ORMs, and am having trouble finding one that will work well.

The Lift ORM looks nice, but I'm not sure it can be decoupled from the entire Lift web framework. ActiveObjects also looks OK, but the author says that it may not work well with Scala.

I'm not coming to Scala from Java, so I don't know all the options. Has anyone used an ORM with Scala, and if so, what did you use and how well did it work?

like image 232
Clinton Dreisbach Avatar asked Jul 16 '09 21:07

Clinton Dreisbach


People also ask

Should you use ORMs?

So, do you need an ORM? If you have any more or less complex project and you work with a relational database, then yes, definitely. Big ORMs seem "bloated" not because they are bad tools, but rather because the underlying problem of object-relational mapping is hard.

Are ORMs slow?

Yes, ORM will slow down your application. By how much depends on how far the abstraction goes, how well your object model maps to the database, and other factors. The question should be, are you willing to spend more developer time and use straight data access or trade less dev time for slower runtime performance.

How does ORM work under the hood?

According to the official definition, it is “A layer of Mappers that moves data between objects and a database while keeping them independent of each other and the mapper itself.” That means that there is a special layer that separates in-memory objects from the database and its main responsibility is to transfer data ...

What is Orm in DBMS?

Object-relational mapping (ORM) is a layer that converts our data between Database and object-oriented entities using object-oriented programming (OOP) language. There are several ORM tools available in the market. Given below are some of the most commonly used tools required to build applications and they are

How to measure the performance of different orms in software development?

To measure the performance, Software developers will have to practically check the performance of different ORMs. Users can download the sample project and required database script files from here. Then later start with setting up a Database environment. 1. Environment Setup – Database

What is the methodology followed by Orms?

So the whole methodology followed by ORMs is dependent on the object-oriented paradigm. ORMs generate objects which map to tables in the database virtually. Once these objects are up, then coders can easily work to retrieve, manipulate or delete any field from the table without paying much attention to language specifically.

What are the different types of orms in OOP?

Some common ORMs and related OOPs language are: 1 Hibernate: JAVA 2 Django ORM: Django 3 SQL Alchemy: Flask 4 Microsoft Entity Framework: .NET framework 5 Dapper ORM: C# 6 JAVA Persistence API: JAVA 7 NHibernate: .NET framework 8 JOOQ ORM: JAVA 9 Doctrine: PHP


Video Answer


1 Answers

There are several reasons why JPA-oriented frameworks (Hibernate, for instance) do not fit into idiomatic Scala applications elegantly:

  • there are no nested annotations as states the Scala 2.8 Preview -- that means you cannot use annotations as mapping metadata for complex applications (even the simplest ones often use @JoinTable -> @JoinColumn);
  • inconsistencies between Scala and Java collections make developers convert collections; there are also cases when it is impossible to map Scala collections to associations without implementing complex interfaces of the underlying framework (Hibernate's PersistentCollections, for example);
  • some very common features, such as domain model validation, require JavaBeans conventions on persistent classes -- these stuff is not quite "Scala way" of doing things;
  • of course, the interop problems (like Raw Types or proxies) introduce a whole new level of issues that cannot be walked around easily.

There are more reasons, I'm sure. That's why we have started the Circumflex ORM project. This pure-Scala ORM tries it's best to eliminate the nightmares of classic Java ORMs. Specifically, you define your entities in pretty much way you would do this with classic DDL statements:

class User extends Record[User] {   val name = "name".TEXT.NOT_NULL   val admin = "admin".BOOLEAN.NOT_NULL.DEFAULT('false') }  object User extends Table[User] {   def byName(n: String): Seq[User] = criteria.add(this.name LIKE n).list }  // example with foreign keys: class Account extends Record[Account] {   val accountNumber = "acc_number".BIGINT.NOT_NULL   val user = "user_id".REFERENCES(User).ON_DELETE(CASCADE)   val amount = "amount".NUMERIC(10,2).NOT_NULL }  object Account extends Table[Account] 

As you can see, these declarations are a bit more verbose, than classic JPA POJOs. But in fact there are several concepts that are assembled together:

  • the precise DDL for generating schema (you can easily add indexes, foreign keys and other stuff in the same DSL-like fashion);
  • all queries can be assembled inside that "table object" instead of being scattered around in DAO; the queries themselves are very flexible, you can store query objects, predicates, projections, subqueries and relation aliases in variables so you can reuse them, and even make batch update operations from existing queries (insert-select for example);
  • transparent navigation between associations (one-to-one, many-to-one, one-to-many and many-to-many-through-intermediate-relation) can be achieved either by lazy or by eager fetching strategies; in both cases the associations are established on top of the foreign keys of underlying relations;
  • validation is the part of framework;
  • there is also a Maven2 plugin that allows generating schema and importing initial data from handy XML formatted files.

The only things Circumflex ORM lacks are:

  • multi-column primary keys (although it is possible to create multi-column foreign keys backed by multi-column unique constraints, but it is only for data integrity);
  • full-fledged documentation (although we are actively working on it);
  • success stories of ten-billion-dollar production systems that have Circumflex ORM as it's core technology.

P.S. I hope this post will not be considered an advertisement. It isn't so, really -- I was trying to be as objective as possible.

like image 147
3 revs Avatar answered Nov 04 '22 00:11

3 revs