- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在使用带有 Hibernate 的 C3P0 连接池来执行一些 JDBC 操作。但是,我在使用一段时间后收到“关闭连接”(SQL 错误:17008,SQLState:空)错误。
我正在使用 org.hibernate.jdbc.Work执行我的操作的界面:
public class ClassThatDoesWork implements Work {
@Override
public void execute(final Connection connection)
throws SQLException {
doSomeWork();
//should connection be closed here?
}
}
我的问题是:作为参数传递给 execute()
方法的 connection
对象是否应该在该方法结束时关闭,或者 Hibernate 会自动处理这个问题?
编辑这些是使用的 Hibernate 和 c3p0 参数:
hibernate.connection.driver_class=oracle.jdbc.driver.OracleDriver
hibernate.connection.pool_size=10
hibernate.dialect=org.hibernate.dialect.Oracle9iDialect
hibernate.connection.provider_class=org.hibernate.connection.C3P0ConnectionProvider
hibernate.show_sql=false
acquireIncrement=3
acquireRetryDelay=500
acquireRetryAttempts=5
breakAfterAcquireFailure=false
checkoutTimeout=0
connectionTesterClassName=com.mchange.v2.impl.DefaultConnectionTester
debugUnreturnedConnectionStackTraces=false
dataSourceName=irrelevantDB
identityToken=irrelevantDB
idleConnectionTestPeriod=0
initialPoolSize=3
maxConnectionAge=0
maxIdleTime=7200
maxIdleTimeExcessConnections=0
maxPoolSize=20
maxStatements=50
maxStatementsPerConnection=0
minPoolSize=5
numHelperThreads=3
propertyCycle=0
testConnectionOnCheckin=false
testConnectionOnCheckout=true
unreturnedConnectionTimeout=0
hibernate.c3p0.min_size=5
hibernate.c3p0.max_size=20
hibernate.c3p0.timeout=10
hibernate.c3p0.max_statements=50
最佳答案
Hibernate 将数据库连接作为方法参数传入,因此不应在方法内部进行篡改(例如关闭)——这是 Hibernate 的责任。
关于java - 是否应该关闭 doWork() 的 "connection"参数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10433145/
我使用的 BackgroundWorker 与以前有点不同。 通常,我使用 BW 来更新一些图形控件,我在 DoWork 方法中执行所有需要的任务,返回结果并为 RunWorkerCompleted
我正在尝试使用 WorkManager 中的 PeriodicWorkRequest 定期从远程 url 获取数据。我已经实现了逻辑,这里的问题是我没有从 Worker 得到任何响应。 但是它似乎在第
这个问题已经以不同的形式被问过很多次,但我没有回答正确,想知道它是否可能不是一个 android 错误。 设置 WorkManager 后,doWork() 会随机调用,有时会连续调用多达 10 次以
我正在寻找在后台线程中运行顺序子过程。我想知道是否可以这样做,方法是创建一个后台工作程序,然后像这样分别调用每个过程... Private Sub BGW_DoWork(ByVal sender As
我正在尝试使用 BackgroundWorker 来完成一项任务。我已经让 worker 正确运行,在 DoWork 方法下它然后调用另一个执行的方法但后来我遇到了我的问题:当该方法试图调用另一个方法
在下面的代码中,有没有一种方法可以不总是订阅 updateWorker_DoWork 方法,而是将它传递给这样的方法 public void GetUpdates(SomeObject blah) {
我正在编写一个基于表单的小型应用程序来连接到 LDAP 服务器,我希望“连接”按钮在后台工作。所以我关注信息和讨论 here 但无论出于何种原因,我的代码似乎都无法正常工作:我在“worker.Run
我正在尝试使用 WorkManager 进行服务器调用。所以,我写了下面的 Worker 类: class ServerCallWorker extends Worker { publ
我想计划任务在 24 小时后从数据库中删除 public class WorkManager extends Worker { public WorkManager(@NonNull Cont
我正在运行一个 BackgroundWorker 线程来完成一项耗时的任务。耗时的任务在另一个类(class)。我需要将在 BackgroundWorker 上运行的这个单独类所取得的进展传递回 Ma
我正在运行一个 BackgroundWorker 线程来完成一项耗时的任务。耗时的任务在另一个类(class)。我需要将在 BackgroundWorker 上运行的这个单独类所取得的进展传递回 Ma
我的问题如下: 我有一个窗口窗体,其中放置了一个 LayoutPanel,当窗体加载时,多个控件,如:文本框和标签被添加到 LayoutPanel。 然后单击按钮,我需要处理用户在那些动态创建的控件上
private void button_uploadToPI_Click(object sender, RoutedEventArgs e) { this.newFilePat
在 form1 之上 label5.Text = "00:00:00"; 在dowork事件中 private void backgroundWorker1_DoWork(object sender,
在我们基于 .NET Framework 的应用程序中,我们使用 BackgroundWorker 保存了一个巨大的文件保持 UI 响应。当我们关闭它时,我们不想停止后台工作(默认行为)并截断文件。
我正在使用后台工作程序来处理文件的加载以阻止我的用户界面卡住,但是似乎 RunWorkerCompleted 在我的 DoWork 事件发生之前完成已完成(退出对话框时导致错误)...我做错了什么吗?
假设我有一个 backgroundWorker1_DoWork,它在数据库中找到一个值并在 e.Result 中返回它。假设我还有一个读取结果的 backgroundWorker1_RunWorker
这是我的设置,这段代码可以正常工作 private void butGo_Click(object sender, EventArgs e) { threadCreateImages.RunWor
我知道 C# 主程序的堆栈大小为 1 MB(32 位和任何)或 4 MB(64 位),请参阅 Why is stack size in C# exactly 1 MB? BackgroundWorke
首先,我贴出我的代码: public partial class MainWindow : Window { private readonly BackgroundWorker worker
我是一名优秀的程序员,十分优秀!