java:使用静态方法获取数据库连接



我正在开发一个现有的基于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

如果可以使用连接池或实体管理器,您最好使用它们!

最新更新