我在我的项目中使用grails 2.3.11和Oracle DB。
我的数据库有问题。 例外:
ERROR (org.hibernate.util.JDBCExceptionReporter) - [99824F7C5386E5A40F94939FF36481FE | admin] - PooledConnection has already been closed.
运行以下代码时出现错误:
@NotTransactional
@Cacheable
def findSmth(String Id) {
//Some logic here
Employee.findWhere(company: company, employee: employee)
}
这段代码重复执行,并在某次迭代时发生错误。
注意:我使用多个数据源。使用以下数据源在数据库中发生错误:
dataSource_employee_ro {
dbCreate = 'validate'
dialect = org.hibernate.dialect.Oracle10gDialect
driverClassName = "oracle.jdbc.driver.OracleDriver"
url = 'jdbc:oracle:thin:@(DESCRIPTION =(ADDRESS = (PROTOCOL = TCP)(HOST = ****)(PORT = 2001))(FAILOVER = true)(LOAD_BALANCE = on)(CONNECT_DATA = (SERVER = DEDICATED)(SERVICE_NAME = ****)(FAILOVER_MODE = (TYPE=select) (METHOD=basic) (RETRIES=10) (DELAY=3))))'
username = '****'
password = '******'
readOnly = true
properties {
maxActive = 10
maxIdle = 5
minIdle = 1
initialSize = 8
testOnBorrow = true
testWhileIdle = true
testOnReturn = false
validationQuery = "SELECT 1 FROM dual"
}
domainSchema = '*****'
}
即使我设置'isPooled = false'(它看起来像“连接已经关闭”),也会出现异常。
我无法弄清楚如何摆脱这个错误。 谁能帮我?感谢。
答案 0 :(得分:0)
我之前遇到同样的问题,问题是因为我在服务中运行一个方法,服务是事务性的,我有另一个线程运行进程到数据库,所以当事务方法结束时,事务关闭与db的连接。
无论如何,我不明白为什么你在方法findBla中使用nonTransactional标签到数据库。应该从服务调用该方法,它应该是事务性的。因此,无需将其标记为非事务性。
我希望我有所帮助:)