Friday, June 18, 2010

RESTful POST Once Exactly (POE) variation

How do you control form POSTs from the client (browser) to the server to prevent a double-submit from being processed twice on the server?

Client : POST "/widget/" Expect: 100-continue []
Server : write new transaction id to db
Server response :
100 Continue, POE: {tranid}
Client : POST "/widget/" POE: {tranid} [body]
Server : POE {tranid} exist in db?
Server : delete {tranid}
Server : Create new resource from [body].
Server response :
201 Created, Location: {newuri} [body]
Client : ...

Hibernate Entity equals - id or others

The Hibernate entity object represents a database table and the Java equals(Object o) method determines identity among entities for a given table.

Hibernate itself identifies rows from a table by their primary keys, following the principles of relational theory as developed by Edgar Codd in the 1960s. Today the id is typically generated automatically by Hibernate and the database engine.


A new theory says that an entity's equals method should not compare ids but should compare all attributes other than the id, i.e. value1 and value2 in the example above.

Arguments FOR comparing attributes other than the id
  • When creating new entities, the entity has no id assigned before it is saved to database, so the id cannot be used to determine identity.
  • It is the various attribute values, not the id, that make up the significance of any row of data.
Q. Would it not be inefficient to compare all the attributes rather than the id?
A. Differences would typically be encountered fairly rapidly making the additional processing negligible.

Arguments AGAINST comparing attributes other than the id
  • Hibernate lazy initialization can be triggered by a comparison after the Hibernate session has ended. Scenarios include cached entities.
  • Regardless of identical attribute values, if the ids are different then there are separate rows in the database.
  • The comparing of ids parallels relational theory, a central principle for all relational databases, also paralleled by Hibernate.

Bottom line

The Hibernate entity equals method should compare IDs.

PHP Love/Hate - Inheritance Depth

Just made the discovery that class inheritance has its limits in PHP. It took several days of pain to discover this, due to the fact that my hosting server (5.1.6) does not run exactly the same version as my dev environment (5.2.5), and the particular transaction I was testing is initiated by PayPal.
Lesson learned:
  • Single inheritance is ok
  • > 1 inheritance depth fails in some versions

I guess I'm spoiled my the elegance of Java and Ruby, expect industrial strength engines. And I have to admit I am no virtuoso in my command of PHP.
Hopefully eclipse Galileo's PDT 2.1 (PHP Development Toolkit) might ease my dev pain.