我正在开发一个现有的基于Java EE的应用程序。这具有以下连接数据库的方法:
public static java.sql.Connection connectionToDataBase(String jndiName,boolean flag)throws Exception
{
DataSource ds =(javax.sql.DataSource) initCtx.lookup(jndiName);
return ds.getConnection();
} catch (NamingException ne) {
throw ne;
} finally {
try {
if (initCtx != null)
initCtx.close();
} catch (NamingException ne) {
throw ne;
}
}
}
我的问题是,使用静态方法连接数据库是否正确?
为什么将函数定义为静态函数?
这并没有错,也没有任何约定会禁止您从非静态方法调用静态方法。根据定义,非静态方法属于类的实例,而静态方法则属于类本身。
拥有一个静态方法意味着您不需要该类的实例来连接到DB。
为了回答您的问题,您可能需要考虑类封装了什么。您是否只希望类的实例能够连接到DB?或者,您希望能够在不引用类的实例的情况下连接到DB?
如果可以使用连接池或实体管理器,您最好使用它们!