A: 

I'm curious as to the nature of the key. Why is the service generating it? Wouldn't an alternative design put that in the database?

It's hard to tell exactly what's wrong without an error message.

duffymo
There is no error; just transaction doesn't start, every insert operation directly goes to Database.
Altug
Also database may change according to location (customer), so i just want to solve it at Java side.
Altug
+1  A: 

Not 100% sure. I think all @Transactional calls must be done on the same thread that a transaction started on. I know for certain that @Transactional doesn't work across threads. (I guess by design)

jvdneste
+3  A: 

Unless you're using code weaving, this can't work.

The default way Spring handles transactions is through AOP proxies. The call to a transactional method goes like this:

 caller --> ProxyClass.a() --> YourClass.a()

If you call another method on the same object, you're not going through the proxy, so there is no transactional behaviour.

 caller --> ProxyClass.a() --> YourClass.a() --> YourClass.b()

If you don't want to use AspectJ, you can get the proxy object using AopContext.currentProxy().

Henning
A: 

If you want to call b() inside of a(), and you want to make b() transactional, you have to put it into separate class.

vrm
A: 

Method call to b() is internal call not on transactional proxy as said by Henning.

Whole thing is explained in this blog post.

Jaydeep