"не найден подходящий драйвер для jdbc" при использовании DataSource (Java Eclipse) - PullRequest
0 голосов
/ 13 января 2019

Я рассмотрел ряд других сообщений о переполнении стека на тему "Не найден подходящий драйвер для jdbc". Однако решения в других статьях, похоже, основаны на использовании DriverManager, который помещает JAR коннектора базы данных в «Путь сборки Java» в Eclipse, например:

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

Я использую другой подход. Я имею время выполнения сервера приложений IBM Liberty в Eclipse. Согласно документации IBM, я поместил JAR в Liberty и настроил свободу с JNDI «jdbc / mySQL».

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>

ХОРОШО

Я могу установить соединение с mySQL, когда создаю сервлет в Eclipse со следующей разметкой. В этом примере сервлетом является «foo.java». При запуске этого сервлета в Liberty в Eclipse, соединение с базой данных успешно .

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.

<%@ 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 Ответ

0 голосов
/ 13 января 2019

Вам не хватает импорта. попробуйте импортировать их.

<%@ page import="java.io.*,java.util.*,java.sql.*"%>
<%@ page import="javax.servlet.http.*,javax.servlet.*" %>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...