我已经查看了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配置了自由。
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页面时,没有找到适合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应用程序服务器上的数据源建立与数据库的连接,则完全可以使用其他方法。
答案 0 :(得分:1)
您缺少进口商品。尝试导入它们。
<%@ page import="java.io.*,java.util.*,java.sql.*"%>
<%@ page import="javax.servlet.http.*,javax.servlet.*" %>