使用 DataSource (Java Eclipse) 时“找不到适合 jdbc 的驱动程序”

Posted

技术标签:

【中文标题】使用 DataSource (Java Eclipse) 时“找不到适合 jdbc 的驱动程序”【英文标题】:"no suitable driver found for jdbc" when using DataSource (Java Eclipse) 【发布时间】:2019-01-13 12:49:29 【问题描述】:

我查看了 Stack Overflow 上有关“找不到适合 jdbc 的驱动程序”的其他一些帖子。但是,其他帖子中的解决方案似乎是使用“DriverManager”,将数据库连接器JAR放在Eclipse的“Java Build Path”中,如下所示:

Class.forName("com.mysql.cj.jdbc.Driver");
conn = DriverManager.getConnection("jdbc:mysql://example.com:3306/foo","john","secret");

我采取了不同的方法。我在 Eclipse 中有 IBM Liberty 应用程序服务器运行时。根据 IBM 的文档,我已将 JAR 放在 Liberty 上,并使用“jdbc/mySQL”的 JNDI 配置了 liberty。

server.xml

<dataSource id="mySQL" jndiName="jdbc/mySQL">
  <jdbcDriver libraryRef="mySQLlibrary"/>
  <properties serverName="example.com" portNumber="3306" databaseName="foo" user="john" password="secret"/>
</dataSource>

<library id="mySQLlibrary">
  <fileset name="/opt/IBM/Liberty/usr/shared/resources/mysql/mysql-connector-java-8.0.11.jar"/>
</library>

好的

当我在 Eclipse 中使用以下标记创建 servlet 时,我能够连接到 mySQL。在本例中,servlet 是“foo.java”。在 Eclipse 中的 Liberty 上运行此 servlet 时,将显示 数据库连接成功

package com.main;

import java.io.*;
import java.sql.*;
import javax.annotation.Resource;
import javax.servlet.*;
import javax.servlet.http.*;
import javax.servlet.annotation.WebServlet;
import javax.sql.DataSource;

@WebServlet("/foo")
public class foo extends HttpServlet 

  @Resource(name = "jdbc/mySQL")
  private DataSource ds1;
  private Connection conn = null;
  private static final long serialVersionUID = 1L;

  public foo() 
    super();
  
  public void doGet(HttpServletRequest request, HttpServletResponse response) 
                                   throws ServletException, 
IOException 
    PrintWriter out = response.getWriter();
    try 
        conn = ds1.getConnection();
         
     catch (SQLException e) 
        e.printStackTrace();
         
         finally 
            if (conn != null)
                out.println("Database connection successful");
            
          
    

不好的

在 Eclipse 中,我使用以下标记创建了 foo.jsp。请注意,我在这里也使用了 JNDI "jdbc/mySQL",就像我在 foo.java servlet 中使用的一样。

<%@ taglib uri="http://java.sun.com/jsp/jstl/sql" prefix="sql" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>

<sql:query var="foo" dataSource="jdbc/mySQL">
    select * from foo;
</sql:query>

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" 
"http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
</head>
<body>
</body>
</html>

丑陋的

当我在 Eclipse 中运行项目并导航到 foo.jsp 页面时,返回 No suitable driver found for jdbc/mySQL

Exception thrown by application class 'org.apache.taglibs.standard.tag.common.sql.QueryTagSupport.getConnection:284'
javax.servlet.jsp.JspException: Unable to get connection, DataSource invalid: "java.sql.SQLException: No suitable driver found for jdbc/mySQL"
at org.apache.taglibs.standard.tag.common.sql.QueryTagSupport.getConnection(QueryTagSupport.java:284)
at [internal classes]
at com.ibm._jsp._test._jspx_meth_sql_query_0(_test.java:137)
at com.ibm._jsp._test._jspService(_test.java:102)
at com.ibm.ws.jsp.runtime.HttpJspBase.service(HttpJspBase.java:100)
at [internal classes]

我不确定需要更改哪些内容才能成功连接到 foo.jsp 中的数据库。我应该提一下,这里不需要使用 JSTL。只要 JSP 页面最终可以通过 Liberty 应用程序服务器上的 DataSource 连接到数据库,其他一些方法就完全可以了。

【问题讨论】:

【参考方案1】:

您缺少导入。尝试导入它们。

<%@ page import="java.io.*,java.util.*,java.sql.*"%>
<%@ page import="javax.servlet.http.*,javax.servlet.*" %>

【讨论】:

谢谢罗希特。添加导入正是需要的。我已经注意到了这一点。感谢您的帮助。

以上是关于使用 DataSource (Java Eclipse) 时“找不到适合 jdbc 的驱动程序”的主要内容,如果未能解决你的问题,请参考以下文章

如何在 Java Web 应用程序中使用 DataSource 测试 DAO?

从 Java 配置 DataSource(无 XML)

使用 DataSource (Java Eclipse) 时“找不到适合 jdbc 的驱动程序”

java学习日记

播放 2 框架单元测试 - java.lang.RuntimeException: DataSource 用户为空?

JAVAEmail工具错误java.lang.ClassNotFoundException: javax.activation.DataSource