当前位置: 首页 > 知识库问答 >
问题:

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

常明亮
2023-03-14

我已经回顾了Stack Overflow上关于“找不到适合jdbc的驱动程序”的许多其他帖子。但是,其他帖子中的解决方案似乎是围绕使用“DriverManager”,将数据库连接器JAR放置在Eclipse中的“JavaBuild Path”中,如下所示:

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

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

服务器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中创建一个与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.javaservlet中使用的一样。

<%@ 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页面,未返回适合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应用服务器上的数据源连接到数据库,其他一些方法就完全可以了。

共有1个答案

罗均
2023-03-14

你错过了进口。试着导入它们。

<%@ page import="java.io.*,java.util.*,java.sql.*"%>
<%@ page import="javax.servlet.http.*,javax.servlet.*" %>
 类似资料:
  • 问题内容: 我正在尝试编写一个程序以在eclipse中连接到MySQL数据库,但出现错误 “ java.sql.SQLException:找不到合适的驱动程序” 。 Java代码是: } 控制台选项卡中的输出为: 我已经使用了MySQL Connector / J。将其解压缩到MySQL安装目录中,并将jar文件添加到CLASSPATH中。 另请参阅此图像。有一个 !在项目根目录上标记。image

  • java。sql。SQLException:找不到适合jdbc的驱动程序:h2:tcp://localhost/当我尝试使用java web应用程序连接到h2数据库时,抛出了~/ZadatakDB。 我可以使用H2控制台没有任何问题,ping是成功的。 我还将h2-1.3.176 jar文件添加到库和WEB-INF/lib中。 下面是我用来连接的Java方法: 我会错过什么? 我还将添加Stack

  • 我的一些代码有问题,我已经搜索并尝试了我所知道的一切,但没有任何运气。 场景: > 应用程序检查JDBC驱动程序是否存在,在本例中是H2驱动程序(org.H2.driver) 如果不存在,应用程序将下载JDBC驱动程序并将其添加到类加载器中,如下所示:(注意:storageDataManager是我用于SQL方法的一个类) 当Storage ageDataManager运行第一个查询时,它会尝试与

  • 我已经检查了这个问题的所有消息,但它是一样的,它不起作用。我必须用java连接到sql服务器2008数据库,我已经添加了sqljdbc4.jar但什么也没有。 我做的不好,如果你还需要什么,请告诉我。 我收到这条消息: Java语言sql。SQLException:未找到适合jdbc的驱动程序:sqlserver://xxx.xxx.xxx.xxx:1433;databaseName=ccis;用

  • 我使用的是用于MariaDB的连接器,但它不起作用。 下面是连接代码: 我得到: 除了将其作为外部jar添加到库之外,我还将其作为驱动程序添加到NetBeans(服务)中的数据库中。此外,如果我删除,它也不能正常工作。

  • 我正在开发一个软件连接到微软SQL数据库 到目前为止,在NetBeans中它工作得很好,但是当尝试在NetBeans创建的dist文件夹中使用jar版本时,我遇到了“找不到合适的驱动程序”错误 这真的很令人费解,因为我已经尝试了我能在网上找到的关于错误的一切,比如: 干净 还有我能找到的任何东西。 我正在使用最新稳定的JRE、JDK和Netbean以及微软的JDBC 4.0。 我不知道我需要为人们