named parameter bind only works on the where clause. what if you want different schema at runtime for the table part. such as
'select * from :tablename where ...'
'update :tablename set ..."
You will find the above won't work in your @Query annotation
use EntityManager::createNativeQuery
data:image/s3,"s3://crabby-images/53cce/53cce4ee710d2f61a8f756739e954fde093e81ae" alt=""
You can get the single result, the first result, result lists or result stream.
data:image/s3,"s3://crabby-images/c91c8/c91c89f4ca7bde8c05ac5a17ca6a375cdaa55707" alt=""
use entityManager.createNativeQuery(sql).executeUpdate()
use executeUpdate to update or delete records in the table
data:image/s3,"s3://crabby-images/4730d/4730d254af0b3c13e6f12b4ab08e25d80461d396" alt=""
Not allowed to create transaction on shared EntityManager
Caused by: java.lang.IllegalStateException: Not allowed to create transaction on shared EntityManager - use Spring transactions or EJB CMT instead
Please call joinTransaction before execute update sql
data:image/s3,"s3://crabby-images/8b8bc/8b8bc8e21693e460cfa6510223bf3c32c2a34e5b" alt=""