siena

Siena is a persistence abstraction layer made in Java with various implementations: * siena-jdbc: persists objects into a relational database using JDBC (status: deeply tested) * siena-gae: persists objects into the Google App Engine's datastore using its low-level API (status: beta) * siena-sdb: persists objects using Amazon's SimpleDB (very experimental) * siena-remote: persists objects remotely using a remote web application that uses siena. (planning) Siena is also: * Intrusive. You make a class persistent by extending a certain class. Relationships are defined also in an intrusive way. * Simple. Simplicity is the most important thing. * Limited. Due to the simplicity there are several unsupported things such as JOINs. * Extensible. There are two interfaces you can implement on your own way.

License

License

Categories

Categories

Maven Build Tools
GroupId

GroupId

com.google.code.maven-play-plugin.com.sienaproject.siena
ArtifactId

ArtifactId

siena
Last Version

Last Version

1.0.0-b6-20111107
Release Date

Release Date

Type

Type

jar
Description

Description

siena
Siena is a persistence abstraction layer made in Java with various implementations: * siena-jdbc: persists objects into a relational database using JDBC (status: deeply tested) * siena-gae: persists objects into the Google App Engine's datastore using its low-level API (status: beta) * siena-sdb: persists objects using Amazon's SimpleDB (very experimental) * siena-remote: persists objects remotely using a remote web application that uses siena. (planning) Siena is also: * Intrusive. You make a class persistent by extending a certain class. Relationships are defined also in an intrusive way. * Simple. Simplicity is the most important thing. * Limited. Due to the simplicity there are several unsupported things such as JOINs. * Extensible. There are two interfaces you can implement on your own way.
Project URL

Project URL

http://www.sienaproject.com
Project Organization

Project Organization

Google Code
Source Code Management

Source Code Management

https://github.com/mandubian/siena

Download siena

How to add to project

<!-- https://jarcasting.com/artifacts/com.google.code.maven-play-plugin.com.sienaproject.siena/siena/ -->
<dependency>
    <groupId>com.google.code.maven-play-plugin.com.sienaproject.siena</groupId>
    <artifactId>siena</artifactId>
    <version>1.0.0-b6-20111107</version>
</dependency>
// https://jarcasting.com/artifacts/com.google.code.maven-play-plugin.com.sienaproject.siena/siena/
implementation 'com.google.code.maven-play-plugin.com.sienaproject.siena:siena:1.0.0-b6-20111107'
// https://jarcasting.com/artifacts/com.google.code.maven-play-plugin.com.sienaproject.siena/siena/
implementation ("com.google.code.maven-play-plugin.com.sienaproject.siena:siena:1.0.0-b6-20111107")
'com.google.code.maven-play-plugin.com.sienaproject.siena:siena:jar:1.0.0-b6-20111107'
<dependency org="com.google.code.maven-play-plugin.com.sienaproject.siena" name="siena" rev="1.0.0-b6-20111107">
  <artifact name="siena" type="jar" />
</dependency>
@Grapes(
@Grab(group='com.google.code.maven-play-plugin.com.sienaproject.siena', module='siena', version='1.0.0-b6-20111107')
)
libraryDependencies += "com.google.code.maven-play-plugin.com.sienaproject.siena" % "siena" % "1.0.0-b6-20111107"
[com.google.code.maven-play-plugin.com.sienaproject.siena/siena "1.0.0-b6-20111107"]

Dependencies

compile (8)

Group / Artifact Type Version
dom4j : dom4j jar 1.6.1
org.apache.ddlutils : ddlutils jar 1.0
com.google.appengine : appengine-api-1.0-sdk jar 1.4.2
com.google.code.maven-play-plugin.org.apache.hbase : hbase jar 0.21.0-20100622
com.h2database : h2 jar 1.3.154
com.google.api.client : google-api-client jar 1.4.1-beta
com.amazonaws : aws-java-sdk jar 1.2.4
org.apache.httpcomponents : httpcore jar 4.1.1

provided (1)

Group / Artifact Type Version
com.google.appengine : appengine-tools-sdk jar 1.4.2

test (9)

Group / Artifact Type Version
junit : junit jar 3.8.2
commons-dbcp : commons-dbcp jar 1.2.2
dbunit : dbunit jar 2.2
mysql : mysql-connector-java jar 5.1.6
postgresql : postgresql jar 8.4-702.jdbc4
org.drizzle.jdbc : drizzle-jdbc jar 1.0
com.google.appengine : appengine-testing jar 1.4.2
com.google.appengine : appengine-api-labs jar 1.4.2
com.google.appengine : appengine-api-stubs jar 1.4.2

Project Modules

There are no modules declared in this project.

Welcome to Siena project!

Latest tagged version is Siena v1.0.0-b5

You can now find some manuals

Siena is a persitence API for Java inspired by the Google App Engine Python Datastore trying to draw a bridge between SQL and NoSQL worlds.
It provides a Java Object-DB mapping designed following the ActiveRecord pattern which brings a simple and intuitive approach to manage your Java objects with respect to the database entities.

Where can you find us also?

  • We have a IRC channel on freenode:
    • irc server: irc.freenode.net:6667
    • channel: #siena
  • You can contact the main committer of Siena using “mandubian” profile in Github or this email: [email protected]

Siena is a single API with many implementations

  • SQL RDBMS (MySQL, Postgres, H2)
  • NoSQL (GAE sync/async for the time being and other implementations are planned such as: MongoDB, SimpleDB, HBase…)

Siena simplifies the transition between NoSQL and SQL

Siena is not meant to mimic a kind of Hibernate for NoSQL+SQL as it would be non-sense. In most cases, a model designed for SQL can be re-used in a NoSQL DB and vis-versa but it might not be optimized for the database. Siena is not meant to modify your model behind your back to optimize it for all the databases because it would be a crazy work. Siena just aims at drawing a bridge between NoSQL/SQL worlds and reduce the effort required when going from one database to the other. It ensures:

  • You can use the same API for all DB.
  • The model you design for a RDBMS will work with the same code in a NoSQL database and vis versa.
  • Naturally, after migrating, you will optimize your model for the new database based on its specificity.
  • When you want to use very specific feature of a database, you will naturally use the low-level APIs provided by this DB.

Siena has a development lifecycle driven by practical use-cases and user experience

Siena doesn’t try to fit in force and hide all the specific database technical aspects into your Java code. It has certainly been a false and unfulfilled promise of ORM frameworks in general: an object is not really a relational entity and SQL can’t be completely hidden behind Java code. Thus, ORM often just moves the problems you had with SQL to problems you have with your ORM framework and unfortunately, you don’t control your ORM framework at all as your SQL.

So we try to design siena (at least as a wishful thinking because it’s not an easy and exact process :)) through a process going from the user needs to the technical aspects of SQL/NoSQL databases and not the other way. As an example, when building a web application, you often need to paginate among hundreds of entities by pages of 50 for ex. You really don’t care how the DB manages its record offsets for SQL or cursors for GAE, you just want a page of 50 entities and then go to the next page and then go back to the previous page etc… So Siena provides a pagination mechanism which allows exactly this without scratching your head and this mechanism has the same behavior in SQL and NoSQL.

As a consequence, Siena is a bit more than just a Object-Mapping API, it’s like a toolbox to help you build your application based on a persistence system.

Siena technical design


A thin layer on top of low-level DB API

Siena is meant to keep the layer between your code and the low-level database APIs as thin as possible in order to make it efficient and not to implement to much technical mechanisms on top of already complex and complete database mechanisms:

  • For SQL, it directly uses JDBC
  • For GAE, it directly uses GAE low-level Datastore

The biggest part of Siena DB implementations is :

  • Mapping from Java types to low level DB types
  • Business code to manage high level mechanism such as pagination or stateless/stateful modes


Siena core is ONE jar and some tools/modules around this core library

Siena tries to be as simple as possible in its dependencies. For the time being, in order to use Siena with all DB implementations, you just need the siena.jar and the DB Jar(s) (JDBC or GAE) but nothing else. There is no hidden or transitive dependencies on other frameworks or Jars. So you can use Siena in a simple Java application or in a simple web app or in a JEE app.

Our purpose is also to provide tools or integrated modules based on this core library to use Siena in given environments.

The first module developed for Siena is play-siena: the web framework Play! is really great, really fits Siena design and provides a very good test platform.


Siena is stateless by default (but can become stateful if required)

Siena is stateless by default because it really fits the majority of cases and one can use it directly without scratching his head about potential problems of releasing DB resources or committing anything. Moreover, stateless is much easier to use in scalable and distributed infrastructure such as GAE.

Yet, Siena now proposes a new stateful mode to be able to reuse DB resources several times. Thus you can:

  • create a query with filters and orders and use the same query several keeping last context alive.
  • iterate through the results while keeping in memory the last position.
  • etc…

This stateful mode provides some interesting advanced features and we don’t know yet all the practices it will bring.
Siena is Open Source and is released under the Apache License 2.0.


Siena provides an asynchronous mode (only for GAE for the time being)

This is a really powerful way of retrieving entities from a database. You create a query, you launch it, you do something else and when the result is ready, you get it. Asynchronism is really useful when you run long duration queries and don’t want to stop all the current thread while the queries is treated.

Siena provides an easy way to go to asynchronous mode and back to synchronous.

Versions

Version
1.0.0-b6-20111107