I have datasource bean initialized in the spring context. I wonder what way should be used? Why I just can not write dataSource.getConnection()?
I have datasource bean initialized in the spring context. I wonder what way should
Share
Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.
Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.
Lost your password? Please enter your email address. You will receive a link and will create a new password via email.
Please briefly explain why you feel this question should be reported.
Please briefly explain why you feel this answer should be reported.
Please briefly explain why you feel this user should be reported.
There is one important difference:
dataSource.getConnection()always returns a new connection obtained from the dataSource or connection pool.DataSourceUtils.getConnection()checks if there is an active transaction for the current thread. If there is one, it will return connection with this transaction. If there is none it will behave exactly the same way asdataSource.getConnection().You need to be careful when using
DataSourceUtils.getConnection(). If it returns connection for the active transaction it means someone else will be closing it since it’s the responsibility of whoever opened the transaction. On the other hand, if it returns a brand new connection from the dataSource it’s you who should commit/rollback/close it.