[jboss-user] [Persistence, JBoss/CMP, Hibernate, Database] - Atomic Transaction Help!!

lemboy4 do-not-reply at jboss.com
Tue Aug 14 23:22:02 EDT 2007


Hi, this question is a bit involved; though all I can offer is my eternal gratitude to somebody who helps me avoid wasting even more hours on understanding this...

I am avoiding using Entity beans for now, and created a set of methods that directly call SQL, something like....

class DBAccess {
     method1(parameters for SQL) {
         open connection();
         execute a statement with these parameters...
         close connection();
      }
      ...
}

Now, I have a message driven bean listening for JMS, and when it receives a message it calls a method in DBAccess that looks like:

method {
      check_if_object_exists_in_DB();
      if(doesnt_exist) {
          create_object_in_DB();
          do_other_stuff_involving_new_object_in_DB();
       }
}

Now, JBoss won't treat this method as atomic no matter what...I get duplicates in the DB in a way that looks certainly like multiple threads are seeing doesnt_exist and creating.

I've tried many things and rejected them:
   -- Consolidate into one statement?  Too complicated, has to be done in multiple queries
   -- Locking database table?  This just pushes the problem a layer lower,  and ruins my whole nice set of SQL methods (used in other places) that just do one thing each, since I believe they could no longer open and close connections individually and would have to all be put together to operate under one connection with the lock
    -- Synchronizing around this method....supposedly very much not allowed in JBoss, and besides the method items then execute in the correct order but STILL I end up with duplicates

If I were using Entity beans I think the thing to do here would be open a "transaction" at the start of the big method that calls all the others...  Am I just going about this all wrong?  I am new to JBoss, is there some brilliant way to structure methods that just execute SQL so this problem never comes up??

Thanks for any help provided!!!!

-Chris

View the original post : http://www.jboss.com/index.html?module=bb&op=viewtopic&p=4074256#4074256

Reply to the post : http://www.jboss.com/index.html?module=bb&op=posting&mode=reply&p=4074256



More information about the jboss-user mailing list