【JavaWeb程序设计】JSP访问数据库

目录

一、安装Mysql,设置好数据库的账户和密码

二、JSP访问数据库的步骤

①加载数据库驱动程序;

②建立连接对象;

③创建语句对象;

④获得结果集;

⑤关闭有关连接对象。

三、实现个人信息的查询和展示

1、新增数据库DBJsp,新增一张表student,包含身份证号、学号、姓名、年龄和性别等字段,并为student表添加一些记录。

2. 编写一个JSP展示页面,能够通过查询数据库获取student表的信息,并使用表格展示表中所有的记录信息。

3. 运行截图

三、心得体会

1. 掌握了JDBC连接mysql数据库的方法,会基本的增删改查操作。


一、安装Mysql,设置好数据库的账户和密码

安装好mysql如下:

​​​​​​​mysql -u root -p

二、JSP访问数据库的步骤

①加载数据库驱动程序;

②建立连接对象;

③创建语句对象;

④获得结果集;

⑤关闭有关连接对象。

三、实现个人信息的查询和展示

1、新增数据库DBJsp,新增一张表student,包含身份证号、学号、姓名、年龄和性别等字段,并为student表添加一些记录。

字段

类型

备注

id

int

记录id

pId

Varchar(32)

身份证

no

Varchar(32)

学号

name

varchar(20)

姓名

sex

varchar(4)

性别

birthdate

datetime

出生日期

建表如下:

插入数据:

查看表格:

2. 编写一个JSP展示页面,能够通过查询数据库获取student表的信息,并使用表格展示表中所有的记录信息。

(connect.jsp)

<%@ page import="java.sql.*" %>
<%--Created by IntelliJ IDEA.User: 86189Date: 2023/10/27JSP访问数据库
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head><title>JSP连接数据库</title><style>table, th, td {border: 1px solid darkgrey;}table {border-collapse: collapse;width: 60%;}</style>
</head>
<%Connection connection = null;PreparedStatement statement = null;ResultSet resultSet = null;String driver = "com.mysql.cj.jdbc.Driver";String url = "jdbc:mysql://localhost:3306/dbjsp";String user = "root";String psword = "abc1234";try {try {Class.forName(driver);} catch (ClassNotFoundException e) {throw new RuntimeException(e);}try {connection = DriverManager.getConnection(url, user, psword);} catch (SQLException e) {e.printStackTrace();}try {//查询语句String query = "SELECT * FROM student";//创建PreparedStatement对象if (connection != null) {statement = connection.prepareStatement(query);}//执行查询if (statement != null) {resultSet = statement.executeQuery();}} catch (SQLException e) {e.printStackTrace();}
%>
<body>
<h1 align="center" style="color: lightpink">学生信息</h1>
<table align="center"><tr align="center"><th>身份证号</th><th>学号</th><th>姓名</th><th>性别</th><th>出生日期</th></tr><% if (resultSet != null) {while (resultSet.next()) { %><tr align="center"><td><%= resultSet.getString("pID") %></td><td><%= resultSet.getString("no") %></td><td><%= resultSet.getString("name") %></td><td><%= resultSet.getString("sex") %></td><td><%= resultSet.getString("birthdate") %></td></tr><% }} %></table>
</body>
</html>
<%} catch (SQLException e) {e.printStackTrace();} finally {// 关闭连接和释放资源try {if (resultSet != null) {resultSet.close();}if (statement != null) {statement.close();}if (connection != null) {connection.close();}} catch (SQLException e) {e.printStackTrace();}}
%>

3. 运行截图

三、心得体会

1. 掌握了JDBC连接mysql数据库的方法,会基本的增删改查操作。

(1)在idea导入jar包

(2)导入MYSQL驱动包

连接MYSQL数据库步骤

  1. 获取数据库连接:要连接到数据库,需要获取一个Connection对象。
  2. 创建SQL语句:在获取数据库连接之后,构建SQL语句并执行查询操作。SQL语句可以使用Statement或PreparedStatement对象来创建,其中PreparedStatement对象可以防止SQL注入攻击。
  3. 处理查询结果:执行SQL语句后得到一个resultSet对象,其中包含了查询结果。可以通过该对象的next()方法遍历结果集,并使用resultSet对象的各种方法获取结果集中的数据。
  4. 关闭数据库连接:在使用完数据库连接之后,需要手动关闭它。通常情况下,应该先关闭ResultSet对象,然后关闭Statement对象,最后关闭Connection对象。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/42348.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Week 5-杨帆-学习总结

目录 46 语义分割和数据集语义分割与其他技术的区别Pascal VOC2012 语义分割数据集数据预处理自定义语义分割数据集类数据加载与批量处理遇到的问题&解决办法 47 转置卷积转置卷积的基本概念转置卷积的基本操作填充和步幅在转置卷积中的作用多通道的转置卷积与矩阵变换的联…

2024年生成式人工智能(AIGC)进化速度太快了,如何帮助我们提升效率呢

在软件工程领域里&#xff0c;生成式人工智能&#xff08;AIGC&#xff09;正悄然重塑着程序员的日常作业模式。从源码的自动编写&#xff0c;到瑕疵的敏锐捕捉&#xff0c;再到测试流程的自主执行&#xff0c;AI驱动的工具已然晋升为编程人员不可或缺的智囊团。尽管如此&#…

Java String操作工具类:StrUtil

在日常的Java开发中&#xff0c;字符串&#xff08;String&#xff09;是最常用的数据类型之一。无论是数据处理、文本分析还是界面展示&#xff0c;都离不开对字符串的精细操作。然而&#xff0c;尽管Java标准库提供了丰富的字符串处理方法&#xff0c;但在实际项目中&#xf…

缓存-缓存使用2

1.缓存击穿、穿透、雪崩 1.缓存穿透 指查询一个一定不存在的数据&#xff0c;由于缓存是不命中&#xff0c;将去查询数据库&#xff0c;但是数据库也无此纪录&#xff0c;我们没有将这次查询的null写入缓存&#xff0c;这将导致这个不存在的数据每次请求都要到存储层去查询&a…

java信号量(Semaphore)

Java中的信号量&#xff08;Semaphore&#xff09;是一种用于控制多个线程对共享资源的访问的同步工具。它可以用来限制可以同时访问某些资源的线程数量。Semaphore 提供了一个计数器来管理许可证的获取和释放&#xff0c;每个许可证代表对资源的一次访问权限。 import java…

如何构建一个可伸缩的微服务架构?

如何构建一个可伸缩的微服务架构&#xff1f; 大家好&#xff0c;我是微赚淘客系统3.0的小编&#xff0c;也是冬天不穿秋裤&#xff0c;天冷也要风度的程序猿&#xff01; 微服务架构是一种将应用程序设计为一组小型服务的架构风格&#xff0c;每个服务运行在自己的进程中&am…

【Python进阶】函数的扩展

函数 目录 函数 一、容器知识补充 1、字典遍历方法 2、遍历字典元素 keys()方法&#xff1a; values()方法&#xff1a; items()方法&#xff1a; 3、公共运算符 4、公共方法 二、函数介绍 1、函数的概念 2、引入函数 3、函数定义与调用 4、函数的参数 5、函数…

机器学习与深度学习:区别(含工作站硬件推荐)

一、机器学习与深度学习区别 机器学习&#xff08;ML&#xff1a;Machine Learning&#xff09;与深度学习&#xff08;DL&#xff1a;Deep Learning&#xff09;是人工智能&#xff08;AI&#xff09;领域内两个重要但不同的技术。它们在定义、数据依赖性以及硬件依赖性等方面…

Unity扩展 Text支持超链接文本

重点提示&#xff1a;当前的文本扩展支持多个超链接&#xff0c;支持修改超链接规则和支持修改超链接颜色。 近期在邮件文本中用到了超链接。最初是在邮件窗口中新加一个按钮用来超链接跳转&#xff0c;之后发现效果表现不如直接在文本中添加&#xff0c;后经过几个小时的资料…

日本服务器托管需要注意哪些问题

日本服务器托管是一项涉及多方面因素的重要决策&#xff0c;为了确保托管服务的稳定、高效与安全&#xff0c;企业或个人在托管过程中需要注意以下几个关键问题&#xff1a; 首先&#xff0c;数据中心的基础设施建设标准是决定托管稳定性的关键。这包括数据中心的建筑抗震、抗洪…

Python学习-套接字方式网口传输图片

1. 发送端 import socket import structdef send_image(filename):# 创建socket对象client_socket socket.socket(socket.AF_INET, socket.SOCK_STREAM)try:client_socket.connect((192.168.129.160, 12345)) # 连接到Ubuntu单片机的IP地址和端口# 发送文件名client_socket.…

拍桌子、甩脸子、抡棒子没用,带出一流战斗力团队用好3招就够了

拍桌子、甩脸子、抡棒子没用&#xff0c;带出一流战斗力团队用好3招就够了 第一招&#xff1a;及时激励 在现实中&#xff0c;绝大部分管理者管理手段缺乏&#xff0c;只知道用钱进行激励。 而真正的高手不仅会满足员工物质上的需求&#xff0c;更注重员工心理上的满足。 他…

Java从入门到精通

本文章描述了以下方向: 1.面向对象与面向过程 面向对象:创建黑白双方的对象负责演算,棋盘的对象负责画布,规则的对象负责判断, 例子可以看出,面向对象更重视不重复造轮子,即创建一次,重复使用。 面向过程:开始—黑走—棋盘—判断—白走—棋盘—判断—循环。只需要关注每…

【澳门风云】用C开发一个模拟一个简单的扑克牌比大小的游戏

效果&#xff1a; 欢迎来到此游戏 电脑的牌已发好&#xff0c;接下来给你发牌 你的牌是&#xff1a;5 请选择是否开牌 选1开牌&#xff0c;选2不开 1&#xff08;用户输入&#xff09; 电脑的牌是&#xff1a;10 玩家胜利&#xff01; 源码&#xff1a; #include<iostream…

水箱高低水位浮球液位开关工作原理

工作原理 水箱高低水位浮球液位开关是一种利用浮球随液位升降来实现液位控制的设备。其基本原理是浮球在液体的浮力作用下上下浮动&#xff0c;通过磁性作用驱动与之相连的磁簧开关的开合&#xff0c;从而实现液位的高低控制和报警。当液位升高时&#xff0c;浮球上浮&#xf…

关于7月1号centos官方停止维护7系列版本导致centos7+版本的机器yum等命令无法使用的解决教程

更换yum源两种方式 第一种 在还能使用yum等命令的情况是执行下面的命令 注意&#xff1a;阿里云和腾讯云二选一即可 一丶 yum源 腾讯云&#xff1a; wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.cloud.tencent.com/repo/centos7_base.repo curl -o /etc/yum.…

04-ArcGIS For JavaScript的可视域分析功能

文章目录 综述代码实现代码解析结果 综述 在数字孪生或者实景三维的项目中&#xff0c;视频融合和可视域分析&#xff0c;一直都是热点问题。Cesium中&#xff0c;支持对阴影的后处理操作&#xff0c;通过重新编写GLSL代码就能实现视域和视频融合的功能。ArcGIS之前支持的可视…

Kubernetes分享

幂等性(Idempotency) 介绍 简单来说&#xff0c;幂等性幂等性(Idempotency)是计算机科学中的一个重要概念&#xff0c;特别是在分布式系统和网络应用中。指的是某个操作可以重复执行多次&#xff0c;但其结果是相同的&#xff0c;不会因为多次执行而改变系统的状态。 https://…

IT之家最新科技热点 | 小米 AI 研究院开创多模态通用模型

人不走空 &#x1f308;个人主页&#xff1a;人不走空 &#x1f496;系列专栏&#xff1a;算法专题 ⏰诗词歌赋&#xff1a;斯是陋室&#xff0c;惟吾德馨 目录 &#x1f308;个人主页&#xff1a;人不走空 &#x1f496;系列专栏&#xff1a;算法专题 ⏰诗词歌…

SpringBoot使用手册

SpringBoot使用手册 1、自动装配 1.1、创建spring Boot项目 在之前的文章中已经专门写过&#xff0c;这里不做赘述。 1.2、pom.xml 1.2.1、版本管理 在学习完maven项目后&#xff0c;我们学习框架时首先阅读的就是pom.xml文件&#xff0c;这里是管理自己该项目中所用到的…