十年桃花晚 2022-07-20 21:44 采纳率: 100%
浏览 125
已结题

JDBC连接数据库读取前台无法显示数据

问题遇到的现象和发生背景

利用德鲁伊连接数据库实现后端读取数据库数据到前端显示 无法读取数据并后台报错

问题相关代码,请勿粘贴截图

实体类

public class Student {
    private Integer stuid;
    private String stuname;
    private Integer age;
    private Integer sex;

    public Student() {
    }

    public Student(Integer stuid, String stuname, Integer age, Integer sex) {
        this.stuid = stuid;
        this.stuname = stuname;
        this.age = age;
        this.sex = sex;
    }

    public Integer getStuid() {
        return stuid;
    }

    public void setStuid(Integer stuid) {
        this.stuid = stuid;
    }

    public String getStuname() {
        return stuname;
    }

    public void setStuname(String stuname) {
        this.stuname = stuname;
    }

    public Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }

    public Integer getSex() {
        return sex;
    }

    public void setSex(Integer sex) {
        this.sex = sex;
    }
}

dao层

public class StudentDaoImpl extends DruidUtil implements StudentDao {
    @Override
    public List<Student> getall() {
        List list=new ArrayList();
        Connection connection =null;
        PreparedStatement preparedStatement=null;
        ResultSet resultSet=null;
        try {
            connection = getConnection();
            preparedStatement = connection.prepareStatement("select * from student");
            resultSet = preparedStatement.executeQuery();
            while(resultSet.next()){
                Student student = new Student();
                student.setStuid(resultSet.getInt("stuid"));
                student.setStuname(resultSet.getString("stuname"));
                student.setAge(resultSet.getInt("age"));
                student.setSex(resultSet.getInt("sex"));
                list.add(student);
            }
        } catch (SQLException e) {
            e.printStackTrace();
        } finally {
            close(connection,preparedStatement,resultSet);
        }

        return list;
    }
}

service

public class StudentServiceImpl implements StudentService {
    private StudentDao studentDao = new StudentDaoImpl();
    @Override
    public List<Student> getall() {
        return studentDao.getall();
    }
}

servlet

@WebServlet(urlPatterns = "/getstus")
public class StudentServlet  extends HttpServlet {

    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        doPost(req, resp);
    }

    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //1.接收请求参数
        //2.调取service层方法
        StudentServiceImpl studentService = new StudentServiceImpl();
        List<Student> getall = studentService.getall();
        //3.跳转页面
        //后台传递数据给前台
        req.setAttribute("stulist",getall);
        req.getRequestDispatcher("/show.jsp").forward(req,resp);
    }
}

util

public class DruidUtil {
    private static DataSource ds;

    static {
        try {
            Properties ppt = new Properties();
            ppt.load(DruidUtil.class.getClassLoader().getResourceAsStream("druid.properties"));
            ds = DruidDataSourceFactory.createDataSource(ppt);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }


    /**
     * 从连接池中取出一个连接给用户
     *
     * @return
     */
    public static Connection getConnection() throws SQLException {
        return ds.getConnection();
    }


    public static void close(Connection conn, Statement state, ResultSet rs) {
        try {
            if (rs != null) {
                rs.close();
            }
        } catch (Exception throwables) {
            throwables.printStackTrace();
        }
        try {
            if (state != null) {
                state.close();
            }
        } catch (Exception throwables) {
            throwables.printStackTrace();
        }
        try {
            if (conn != null) {
                conn.close();
            }
        } catch (Exception throwables) {
            throwables.printStackTrace();
        }
    }
}

配置文件
```java
url=jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8
username=root
password=LYSlys0428
driverClassName=com.mysql.jdbc.Driver
initialSize=5
maxActive=10
minIdle=5
maxWait=3000
jsp
```java
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
  <title>$Title$</title>
</head>
<body>
<a href="getstus">查询学生列表</a>
</body>
</html>


jsp

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<html>
<head>
    <title>Title</title>
</head>
<body>
<h1>show.jsp</h1>
<table border="1" width="500px" bgcolor="aqua">
    <tr>
        <td>id</td>
        <td>name</td>
        <td>age</td>
        <td>sex</td>
    </tr>
    <c:forEach items="${stulist}" var="stu">
        <tr>
            <td>${stu.stuid}</td>
            <td>${stu.stuname}</td>
            <td>${stu.age}</td>
            <td>${stu.sex==1?"男":"女"}</td>
        </tr>
    </c:forEach>
</table>
</body>
</html>

代码结构

img

运行结果及报错内容

img

img

我的解答思路和尝试过的方法

前台只能出现样式,无法读取到数据

img

我想要达到的结果

点击超链,读取数据库数据并显示

  • 写回答

9条回答 默认 最新

  • 原来我不知道啊 2022-07-21 10:14
    关注

    试试:
    1、在jdbc_url中,加上 useSSL=false&useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC
    2、将驱动类改成:com.mysql.cj.jdbc.Driver,加个 .cj,因为使用的是8.x的驱动;

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
  • itinjp 2022-07-20 22:09
    关注

    报错的全部信息都贴上来

    评论
  • 学习日记 后端领域新星创作者 2022-07-20 22:15
    关注

    你把你的报错原因截个图呀,其实你把这么多拿过来,关键的却一个没有,比如druid.properties,还有具体报错,就光看这个我认为是你的数据库没有链接成功

    评论
  • 卖柴火的小伙子 2022-07-20 22:29
    关注

    这个应该是和mysql 版本有关系。query_cache_size在The query cache在 MySQL 5.7.20中已过时,在MySQL 8.0中已经移除不用了。不清楚你的mysql版本。https://dev.mysql.com/doc/refman/5.7/en/query-cache.html
    可以尝试去修改mysql-connector-java的版本号。

    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>5.1.45</version>
        <scope>runtime</scope>
    </dependency>
    

    如有帮助,欢迎采纳!

    评论
  • IT技术分享社区 数据库领域优质创作者 2022-07-20 23:16
    关注

    mysql-connecter-java的版本过低,数据库驱动程序与数据库版本不对应 ,如果是用maven的话可以修改版本号重新拉取jar包

    <!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>6.0.6</version>
    </dependency>
    ```xml
    
    
    

    ```

    评论
  • eq0284 2022-07-20 23:42
    关注

    mysql驱动版本过低,你的数据库版本高,query_cache_size在mysql升到8.0时已经移除。升级本地驱动jar包

    望采纳,您的采纳就是我最大的动力,谢谢

    评论
  • 与猿共舞 2022-07-21 07:41
    关注

    网络层渲染错误。检查网络和数据库

    评论
  • bug_keng 2022-07-21 08:20
    关注

    https://blog.csdn.net/weixin_44563573/article/details/115343107?spm=1001.2101.3001.6650.7&utm_medium=distribute.pc_relevant.none-task-blog-2%7Edefault%7EBlogCommendFromBaidu%7Edefault-7-115343107-blog-114136668.pc_relevant_multi_platform_whitelistv1&depth_1-utm_source=distribute.pc_relevant.none-task-blog-2%7Edefault%7EBlogCommendFromBaidu%7Edefault-7-115343107-blog-114136668.pc_relevant_multi_platform_whitelistv1&utm_relevant_index=10

    1.驱动的名称改了
    driver-class-name: com.mysql.cj.jdbc.Driver #mysql8的版本

    2.url: jdbc:mysql://localhost:3306/business?useSSL=true&userUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai
    数据库连接后面加上?useSSL=true&userUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai

    评论
  • 小甘说码 2022-07-21 11:39
    关注

    sql有问题呀,这不提示得很明显嘛,检查一下你写的东西。

    评论
查看更多回答(8条)

报告相同问题?

问题事件

  • 系统已结题 7月29日
  • 已采纳回答 7月21日
  • 修改了问题 7月20日
  • 修改了问题 7月20日
  • 展开全部

悬赏问题

  • ¥15 我用C语言easyx图形库绘制了一个3d游戏方框透视,但进入游戏时候鼠标准星对准方框边缘 鼠标光标就会弹出来这是啥情况怎样让光标对准绘制的方框点击鼠标不弹出光标好烦这样
  • ¥20 用Power Query整合的问题
  • ¥20 基于python进行多背包问题的多值编码
  • ¥15 相同型号电脑与配置,发现主板有一台貌似缺少了好多元器件似的,会影响稳定性和使用寿命吗?
  • ¥15 要求编写稀疏矩阵A的转置矩阵的算法
  • ¥15 编写满足以下要求的停车场管理程序,设停车场只有一个可停放n辆车的狭窄通道且只有一个大门可供车辆进出。
  • ¥15 C语言:数据子序列基础版
  • ¥20 powerbulider 导入excel文件,显示不完整
  • ¥15 用keil调试程序保证结果进行led相关闪烁
  • ¥15 paddle训练自己的数据loss降不下去