Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/303.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java JDBC/Connectorj:何时加载驱动程序?_Java_Mysql_Jdbc - Fatal编程技术网

Java JDBC/Connectorj:何时加载驱动程序?

Java JDBC/Connectorj:何时加载驱动程序?,java,mysql,jdbc,Java,Mysql,Jdbc,我想知道为我的Javaservlet加载驱动程序的“正确”方法是什么 目前,我有一个InitializeDrivers()函数,我在应用程序开始时调用它 public static boolean InitializeDrivers() { try { Class.forName("com.mysql.jdbc.Driver"); return true; } catch (ClassNotFoundException ex) {

我想知道为我的Javaservlet加载驱动程序的“正确”方法是什么

目前,我有一个InitializeDrivers()函数,我在应用程序开始时调用它

public static boolean InitializeDrivers()
{
    try {
        Class.forName("com.mysql.jdbc.Driver");
        return true;
    } catch (ClassNotFoundException ex) {
        // log error
        return false;
    }
}
完成后,根据收到的HTTP请求,我继续执行对数据库的各种请求/插入。但是,由于我的servlet每秒可以接收数百个请求,因此将为每个请求调用InitializeDrivers()


这是正确的方法,还是有一种方法可以只加载一次驱动程序?

当您在servlet中使用数据库时,最好让servlet容器通过连接池管理数据库连接,而不是直接在servlet中获取数据库连接

打开与数据库服务器的连接是一个相对缓慢的操作。此外,数据库可以同时处理的连接数也是有限的。当您每次需要访问数据库时打开数据库连接时,您的应用程序速度会很慢,并且伸缩性不强。此外,数据库连接不是线程安全的,所以不能将数据库连接存储在servlet的静态成员变量中并每次都使用它

连接池为您管理许多打开的连接(这样您就不必每次需要访问数据库时都打开连接),并管理同时打开的连接数。例如,在ApacheTomcat中,您可以对此进行配置,以便通过JNDI查找
javax.sql.DataSource
对象,然后使用JNDI从中获取
连接
对象

本页介绍如何配置Tomcat并在servlet中使用
数据源

public class MyServlet extends HttpServlet {
    static {
        Class.forName("com.mysql.jdbc.Driver");
    }

    // ...
}

如果您不想这样做,并且希望继续使用servlet中的数据库连接(我不建议这样做),则可以在servlet中的静态初始值设定项块中加载驱动程序:

public class MyServlet extends HttpServlet {
    static {
        Class.forName("com.mysql.jdbc.Driver");
    }

    // ...
}

请注意,在JDBC4.0中,不再需要显式加载驱动程序;只要驱动程序在类路径中,JDBC就会自动找到它们。

我开始使用连接池,这就引出了另一个问题。如果您不介意再次分享您的专业知识:)