请教:用单例模式封装了数据库连接的connection,需要关闭吗?

lyp907093825 2012-02-23 02:12:49
请教:用单例模式封装了数据库连接的connection,需要关闭吗?如果关闭会不会出问题,比如说:A线程拿到了连接connection,B线程同时也拿到了。A的事务完成后提交了,把connection关闭,B线程会不会出问题?


package com.gzsoft.secondWeb.util;
import java.io.IOException;
import java.io.InputStream;
import java.sql.*;
import java.util.Properties;
/**
* 单例的模式
* @author lyp
*
*/
public class DB {

private static Connection conn=null;
private static String driver;
private static String connectionURL;
private static String username;
private static String password;

static{
Properties p=new Properties();
InputStream in=DB.class.getClassLoader().getResourceAsStream("connection.properties");
try {
p.load(in);
driver=p.getProperty("driver");
connectionURL=p.getProperty("connection_URL");
username=p.getProperty("username");
password=p.getProperty("password");

} catch (IOException e) {
}

}

public static Connection getConnetion(){
if(conn==null){
try {

Class.forName(driver).newInstance();
DriverManager.getConnection(connectionURL,username,password);
System.out.print("success to connect to database!");
} catch (InstantiationException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
} catch (ClassNotFoundException e) {
System.out.println("can't find the Driver");
} catch (SQLException e) {
System.out.println("fail to connect to database!");
}

}
return conn;

}
public static void closeAll(ResultSet rs,PreparedStatement psmt,Connection conn){
if(rs!=null){
try {
rs.close();
rs=null;
} catch (SQLException e) {
e.printStackTrace();
}
}
if(psmt!=null){
try {
psmt.close();
psmt=null;
} catch (SQLException e) {
e.printStackTrace();
}
}
if(conn!=null){
try {
conn.close();
conn=null;
} catch (SQLException e) {
e.printStackTrace();
}
}

}

public static void main(String[] args) {
System.out.println("driver:"+driver+" connURL:"+connectionURL+" username:"+username+" password:"+password);
getConnetion();
}

}


...全文
484 5 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
MiceRice 2012-02-23
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 lyp907093825 的回复:]
多谢指教,我想知道是connection是不是实现了线程安全的啊?
[/Quote]

没有,数据库连接的机制就是每次只能供一个客户(线程)使用,否则事务管理就乱套了。

如果想节省资源不要重复连接数据库之类的,可以用连接池。
lyp907093825 2012-02-23
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 goldenfish1919 的回复:]
(1)你这个不叫单例模式,没看到instance在哪

(2)与数据库的连接不能用单例。
比如:100个用户在访问,只有1个与数据库的连接,岂不乱套了!
[/Quote]
多谢指教,我想知道是connection是不是实现了线程安全的啊?
若鱼1919 2012-02-23
  • 打赏
  • 举报
回复

(1)你这个不叫单例模式,没看到instance在哪

(2)与数据库的连接不能用单例。
比如:100个用户在访问,只有1个与数据库的连接,岂不乱套了!

ll894311655 2012-02-23
  • 打赏
  • 举报
回复
需要关闭。。。。

81,122

社区成员

发帖
与我相关
我的任务
社区描述
Java Web 开发
社区管理员
  • Web 开发社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧