java 静态sql_多线程-在多线程系统中使用静态java.sql.Connection实例是否安全?

在静态连接对象线程中使用安全吗?

绝对不!

这样,连接将在所有用户发送的所有请求之间共享,因此所有查询将相互干扰。 但是线程安全不是您唯一的问题,资源泄漏也是您的另一个问题。 您将在整个应用程序的生命周期内保持单个连接的打开状态。 只要数据库打开的时间过长(通常在30分钟到8小时之间),平均数据库就会收回该连接,具体取决于数据库的配置。 因此,如果您的Web应用程序运行时间超过此时间,则连接将丢失,并且您将不再能够执行查询。

当这些资源作为多次重复使用的类实例的非DataSource实例变量持有时,此问题也适用。

您应该始终在尽可能短的范围内获取并关闭连接,语句和结果集,最好在与根据以下JDBC惯用法执行查询的位置相同的DataSource块内:

public User find(String username, String password) throws SQLException {

User user = null;

try (

Connection connection = dataSource.getConnection();

PreparedStatement statement = connection.prepareStatement("SELECT id, username, email FROM user WHERE username=? AND password=md5(?)");

) {

statement.setString(1, username);

statement.setString(2, password);

try (ResultSet resultSet = statement.executeQuery()) {

if (resultSet.next()) {

user = new User();

user.setId(resultSet.getLong("id"));

user.setUsername(resultSet.getString("username"));

user.setEmail(resultSet.getString("email"));

}

}

}

return user;

}

请注意,您不应在此处返回DataSource。 您应该立即读取它并将其映射到非JDBC类,然后将其返回,以便可以安全地关闭ResultSet。

如果尚未使用Java 7,请使用DataSource块,在该块中,以相反的顺序手动关闭可关闭资源,因为它们已获得。 您可以在此处找到一个示例:在JDBC中应多久关闭一次Connection,Statement和ResultSet?

如果您担心连接性能,则应该改用连接池。 它内置在许多Java EE应用程序服务器中,甚至像Tomcat这样的准系统servlet容器也支持它。 只需在服务器本身中创建JNDI数据源,然后让您的Web应用将其抓取为DataSource。它显然已经是一个连接池。 您可以在下面列表的第一个链接中找到示例。

也可以看看:

如何在基于servlet的应用程序中连接到JDBC数据库/数据源?

当我的应用失去连接时,我应该如何恢复它?

我在使用JDBC连接池吗?

使用MVC和DAO模式在JSP页面的HTML中显示JDBC ResultSet

DAO JDBC教程

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值