2025年5月22日 星期四 乙巳(蛇)年 二月廿四 设为首页 加入收藏
rss
您当前的位置:首页 > 计算机 > 编程开发 > JSP

JSP JDBC访问数据库

时间:01-29来源:作者:点击数:112

动态网页的主要特点就是能及时更新数据,这些更新的数据来源于数据库。学习本节内容需要您了解 JDBC,可以使用 JDBC 连接 MySQL 数据库。

本节数据库使用 MySQL 5.7,你可以点击 MySQL 官方网站 下载相应的 jar 包。

注意:MySQL 8.0 及之后的版本与之前的数据库连接有所不同:

  • 首先驱动 com.mysql.jdbc.Driver 更换为 com.mysql.cj.jdbc.Driver。
  • MySQL 8.0 及以上版本需要显式关闭 SSL 连接和指定 CST。

MySQL 8.0 及以上版本加载驱动与连接数据库方式如下:

  • <sql:setDataSource var="snapshot" driver="com.mysql.cj.jdbc.Driver"
  • url="jdbc:mysql://localhost:3306/test?useSSL=false&serverTimezone=UTC&useUnicode=true&characterEncoding=utf-8
  • user="root" password="root"/>

下面使用 JSTL 对数据表中的数据进行增删改查。

示例

创建 website 数据表,并插入数据。点击下载 SQL 文件(下载后需要解压)

crud.jsp 代码如下:

  • <%@ page language="java" contentType="text/html; charset=UTF-8"
  • pageEncoding="UTF-8"%>
  • <%@ page import="java.io.*,java.util.*,java.sql.*"%>
  • <%@ page import="javax.servlet.http.*,javax.servlet.*"%>
  • <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
  • <%@ taglib uri="http://java.sun.com/jsp/jstl/sql" prefix="sql"%>
  • <!DOCTYPE html>
  • <html>
  • <head>
  • <title>城东书院(www.cdsy.xyz)</title>
  • </head>
  • <body>
  • <%--
  • JDBC驱动名、数据库 URL、数据库的用户名与密码
  • useUnicode=true&characterEncoding=utf-8 防止中文乱码
  • --%>
  • <sql:setDataSource var="snapshot" driver="com.mysql.jdbc.Driver"
  • url="jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8"
  • user="root" password="root" />
  • <%-- 插入数据
  • <sql:update dataSource="${snapshot}" var="result">
  • INSERT INTO website (NAME,url,age,country) VALUES ('京东', 'https://www.jd.com/', 15, 'CN');
  • </sql:update> --%>
  • <%-- 删除website表中id为9数据
  • <c:set var="id" value="9" />
  • <sql:update dataSource="${snapshot}" var="count">
  • DELETE FROM website WHERE id = ?
  • <sql:param value="${id}" />
  • </sql:update>--%>
  • <%-- 修改website表中id为8数据
  • <c:set var="id" value="8" />
  • <sql:update dataSource="${snapshot}" var="count">
  • UPDATE website SET name="biancheng" WHERE id = ?
  • <sql:param value="${id}" />
  • </sql:update>--%>
  • <%-- 查询数据 --%>
  • <sql:query dataSource="${snapshot}" var="result">
  • SELECT * from website;
  • </sql:query>
  • <table border="1" width="100%">
  • <tr>
  • <th>id</th>
  • <th>name</th>
  • <th>url</th>
  • <th>age</th>
  • <th>country</th>
  • </tr>
  • <c:forEach var="row" items="${result.rows}">
  • <tr>
  • <td><c:out value="${row.id}" /></td>
  • <td><c:out value="${row.name}" /></td>
  • <td><c:out value="${row.url}" /></td>
  • <td><c:out value="${row.age}" /></td>
  • <td><c:out value="${row.country}" /></td>
  • </tr>
  • </c:forEach>
  • </table>
  • </body>
  • </html>

运行结果如下:

查询数据
查询数据
添加数据
添加数据
修改数据
修改数据
删除数据
删除数据
方便获取更多学习、工作、生活信息请关注本站微信公众号城东书院 微信服务号城东书院 微信订阅号
推荐内容
相关内容
栏目更新
栏目热门