idea tomcat mysql jsp 增删改查
时间: 2023-05-14 17:02:29 浏览: 48
"idea"是指IDEA开发工具,"tomcat"是指web服务器,"mysql"是指数据库管理系统,"jsp"是指Java服务器页面。这四个工具组合在一起,可以实现对数据库的增删改查功能。
首先,需要在IDEA中创建一个新的Java web项目。然后,需要将Apache Tomcat服务器集成到项目中,以便于启动web应用程序。在这个项目中,可以访问MySQL数据库,通过连接数据库,可以创建表格并将数据插入其中。
接下来,可以创建JSP页面,通过页面显示数据,同时,还可以实现对数据库的增删改查功能。对于增加数据,可以通过表单提交将数据保存到数据库中。对于删除和修改数据,可以通过SQL语句从数据库中删除或修改指定的数据。对于查询数据,可以通过SQL语句从数据库中检索需要的数据,并通过JSP页面显示检索结果。
在实现增删改查功能时,需要注意保证数据的安全性。可以使用一些安全技术,例如加密、过滤和验证用户的输入。同时,需要使用正确的SQL语句,以确保数据的完整性和正确性。在编写JSP页面时,还需要使用正确的HTML和CSS代码,以确保页面的可访问性和可用性。
综上所述,通过使用IDEA、Tomcat、MySQL和JSP,可以实现对数据库的增删改查功能。在使用这些工具时,需要注意数据的安全性和完整性。这些工具可以将Web应用程序变得更加高效和可靠。
相关问题
jsp+servlet+idea+mysql+tomcat的增删改查
### 回答1:
JSP+Servlet+IDEA+MySQL+Tomcat 的增删改查是指使用 JSP 和 Servlet 技术实现基于 MySQL 数据库的增加、删除、修改和查询功能。IDEA 是用来开发 JSP 和 Servlet 的集成开发环境,Tomcat 则是用来部署和运行 JSP 和 Servlet 应用程序的服务器。这些技术配合使用可以实现强大的 Web 应用程序。
### 回答2:
随着Java技术的不断发展,JSP和Servlet技术已成为企业应用开发中最常用的Web开发技术之一。在JSP和Servlet中,最常见的操作是增删改查(CRUD),这是Web应用程序中最基本和重要的操作之一。
JSP(Java Server Pages)是Java企业版编程中用于创建动态网络页面的一组技术。JSP是通过将Java代码插入HTML页面中来实现动态内容的生成。JSP将Java代码插入HTML页面中,以便在运行时可以动态生成网页内容。使用JSP,您可以轻松地通过简单的HTML标记和初始化JavaBean对象来开发动态Web应用程序。
Servlet(Java Servlet)是由Java编写的服务器端程序,它根据请求动态生成网页内容。Servlet是在服务器端处理HTTP请求和响应的Java类。Servlet可以用于构建动态Web应用程序。Servlet可以与JSP一起使用,以便创建动态内容和生成动态Web页面。
在Java Web应用程序中,Servlet和JSP经常一起使用。Servlet通常用于处理HTTP请求和响应,并提供与底层数据源的通信,而JSP通常用于生成并显示由Servlet返回的响应。JSP和Servlet结合使用的好处是可以分离交互和显示信息的逻辑,使代码更清晰易懂。
关于增删改查在Java Web应用程序中的实现,通常需要针对不同的数据源(例如MySQL)进行操作。MySQL是一种开源的关系型数据库,广泛应用于Java Web应用程序中。Java应用程序可以通过使用MySQL JDBC驱动程序与MySQL数据库进行通信。
在Java Web应用程序中,使用JSP和Servlet访问MySQL数据库以进行增删改查操作是非常常见的。使用JSP,可以编写用于显示数据的动态页面,并使用Servlet进行数据库连接和数据读取。在Java应用程序中,使用JavaBean对象来表示要在页面上显示的数据。
Tomcat是一种Java Servlet容器,它允许在Java Web应用程序中运行Java Servlet。Tomcat提供了一个Web服务器,用于将HTTP请求与Java Servlet映射到Java应用程序中。Tomcat可以与JSP和Servlet一起使用,以构建动态Web应用程序。
综上所述,JSP、Servlet、MySQL和Tomcat是构建Java Web应用程序的重要组件之一。使用JSP和Servlet可以轻松地创建动态Web页面,并与MySQL数据库进行通信以进行增删改查操作。Tomcat作为Java Servlet容器,可以使Java Web应用程序在服务器上运行。把这些技术组合起来,可以构建强大的Java Web应用程序,提供动态内容和实时数据更新。
### 回答3:
JSP、Servlet、IDEA、MySQL和Tomcat是现代Web开发中不可缺少的组件。在Web开发中,通常需要对数据库进行增删改查操作,这也是这些组件的主要功能之一。
JSP是一种用于创建动态Web页面的技术。它允许开发人员在HTML页面中嵌入Java代码,以便动态生成页面。JSP提供了许多内置对象,如request和response对象,以便开发人员可以轻松地访问表单数据和HTTP请求的详细信息。要进行数据库操作,JSP可以通过JDBC连接到MySQL数据库。使用JDBC,可以编写Java代码来执行SQL语句,包括INSERT、UPDATE和DELETE语句以及SELECT语句。
Servlet是Java编写的Web应用程序,可以处理HTTP请求并生成响应。当收到HTTP请求时,Servlet会读取请求的内容并向客户端发送HTML响应。Servlet也可以访问数据库,并执行必要的操作。通过这种方式,开发人员可以设计Java类来处理数据库操作,这些类可以是单独的Java类或Servlet类。与JSP类似,Servlet也可以使用JDBC连接到MySQL数据库。
IDEA是一种集成开发环境,为开发人员提供了许多工具来简化Web应用程序的开发。IDEA可以为开发人员提供高级的代码编写、调试和测试功能,以更轻松地管理Web应用程序。IDEA也可以与MySQL数据库进行集成,并提供了方便的界面,以便管理数据库中的表和数据。
MySQL是一种开源数据库,用于存储和管理数据。MySQL提供了许多功能,如索引、存储过程和触发器,以帮助开发人员更好地管理数据。MySQL还支持事务,这是一种将多个数据库操作视为一个单元执行的机制,以确保数据的完整性和一致性。
最后,Tomcat是一种Web服务器,用于托管和运行Web应用程序。Tomcat可以将JSP和Servlet编译成Java Servlet,并提供了容器,使得这些Servlet可以通过HTTP协议与客户端通信。使用Tomcat,开发人员可以轻松部署Web应用程序,并将其提供给互联网上的用户。
综上所述,JSP、Servlet、IDEA、MySQL和Tomcat是现代Web开发中不可缺少的组件。通过它们,可以创建动态和交互的Web应用程序,并轻松地进行数据库操作。在Web开发中进行增删改查操作时,这些组件起着至关重要的作用,可以大大提高生产力,同时提供高效和可靠的Web应用程序。
javaweb + mysql+servlet实现增删改查
以下是使用Java Web和MySQL数据库实现增删改查的步骤:
1.创建数据库和表
首先,需要在MySQL数据库中创建一个数据库和一个表。例如,创建一个名为“test”的数据库和一个名为“users”的表,其中包含id、name和age三个字段。
2.创建Java Web项目
使用IDE(如Eclipse或IntelliJ IDEA)创建一个Java Web项目,并添加MySQL数据库驱动程序(如mysql-connector-java-5.1.47.jar)到项目的lib文件夹。
3.创建实体类
创建一个名为“User”的Java类,该类包含id、name和age三个属性,并生成getter和setter方法。
4.创建DAO类
创建一个名为“UserDao”的Java类,该类包含对数据库进行增删改查操作的方法。例如,添加一个名为“addUser”的方法,该方法将一个User对象添加到数据库中。
```java
public class UserDao {
private Connection conn;
public UserDao(Connection conn) {
this.conn = conn;
}
public void addUser(User user) throws SQLException {
String sql = "INSERT INTO users (name, age) VALUES (?, ?)";
PreparedStatement pstmt = conn.prepareStatement(sql);
pstmt.setString(1, user.getName());
pstmt.setInt(2, user.getAge());
pstmt.executeUpdate();
}
}
```
5.创建Servlet类
创建一个名为“UserServlet”的Java类,该类包含处理HTTP请求的方法,并使用UserDao类执行数据库操作。例如,添加一个名为“addUser”的方法,该方法从HTTP请求中获取用户输入的数据,并将其添加到数据库中。
```java
public class UserServlet extends HttpServlet {
private UserDao userDao;
public void init() {
String url = "jdbc:mysql://localhost:3306/test";
String user = "root";
String password = "123456";
try {
Class.forName("com.mysql.jdbc.Driver");
Connection conn = DriverManager.getConnection(url, user, password);
userDao = new UserDao(conn);
} catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
}
}
public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
String name = request.getParameter("name");
int age = Integer.parseInt(request.getParameter("age"));
User user = new User();
user.setName(name);
user.setAge(age);
try {
userDao.addUser(user);
response.sendRedirect("list.jsp");
} catch (SQLException e) {
e.printStackTrace();
}
}
}
```
6.创建JSP页面
创建一个名为“list.jsp”的JSP页面,该页面显示从数据库中检索的用户数据。例如,使用UserDao类的“getUserList”方法检索数据库中的所有用户,并在JSP页面中显示它们。
```java
<%@ page contentType="text/html; charset=UTF-8" language="java" %>
<%@ page import="java.util.List" %>
<%@ page import="javax.servlet.http.*" %>
<%@ page import="javax.servlet.*" %>
<%@ page import="java.sql.*" %>
<%@ page import="User" %>
<%@ page import="UserDao" %>
<%
String url = "jdbc:mysql://localhost:3306/test";
String user = "root";
String password = "123456";
try {
Class.forName("com.mysql.jdbc.Driver");
Connection conn = DriverManager.getConnection(url, user, password);
UserDao userDao = new UserDao(conn);
List<User> userList = userDao.getUserList();
%>
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>User List</title>
</head>
<body>
<table>
<tr>
<th>ID</th>
<th>Name</th>
<th>Age</th>
</tr>
<%
for (User user : userList) {
%>
<tr>
<td><%= user.getId() %></td>
<td><%= user.getName() %></td>
<td><%= user.getAge() %></td>
</tr>
<% } %>
</table>
</body>
</html>
<%
} catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
}
%>
```
7.部署和运行
将Java Web项目部署到Tomcat服务器上,并在浏览器中访问“http://localhost:8080/user/add”页面,以添加一个新的用户。然后访问“http://localhost:8080/user/list”页面,以检索并显示所有用户。
相关推荐


好的,下面是详细的教程:
1. 环境准备
首先,需要准备好以下环境:
- IDEA 2020版本
- JDK 1.8或以上
- Maven
- Tomcat
2. 创建Maven项目
打开IDEA,选择File -> New -> Project,选择Maven,在左侧选项卡中选择Web Application,点击Next。在下一个页面中输入Group Id和Artifact Id,然后点击Next。
在下一个页面中,输入项目名称和路径,然后点击Finish。IDEA会自动创建一个Maven项目,并且生成一些基本的文件和目录结构。
3. 配置pom.xml
打开项目的pom.xml文件,添加以下依赖:
xml
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>${mybatis.version}</version>
</dependency>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis-spring</artifactId>
<version>${mybatis-spring.version}</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>${mysql.version}</version>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>${servlet.version}</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>javax.servlet.jsp-api</artifactId>
<version>${jsp.version}</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>jstl</groupId>
<artifactId>jstl</artifactId>
<version>${jstl.version}</version>
</dependency>
其中,${spring.version}、${mybatis.version}、${mybatis-spring.version}、${mysql.version}、${servlet.version}和${jsp.version}都是需要在pom.xml中定义的变量,例如:
xml
<spring.version>5.2.9.RELEASE</spring.version>
<mybatis.version>3.5.6</mybatis.version>
<mybatis-spring.version>2.0.6</mybatis-spring.version>
<mysql.version>8.0.21</mysql.version>
<servlet.version>3.1.0</servlet.version>
<jsp.version>2.3.3</jsp.version>
<jstl.version>1.2</jstl.version>
4. 配置web.xml
在src/main/webapp/WEB-INF目录下创建web.xml文件,并添加以下内容:
xml
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee
http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
id="WebApp_ID" version="3.1">
<display-name>SSM Maven Webapp</display-name>
<servlet>
<servlet-name>dispatcherServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
contextConfigLocation
classpath:spring/spring-mvc.xml
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>dispatcherServlet</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
<context-param>
contextConfigLocation
classpath:spring/spring-context.xml
</context-param>
org.springframework.web.context.ContextLoaderListener
<filter>
<filter-name>encodingFilter</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<init-param>
encoding
UTF-8
</init-param>
<init-param>
forceEncoding
true
</init-param>
</filter>
<filter-mapping>
<filter-name>encodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<jsp-config>
<jsp-property-group>
<url-pattern>*.jsp</url-pattern>
UTF-8
</jsp-property-group>
</jsp-config>
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
</web-app>
5. 编写Spring配置文件
在src/main/resources目录下创建spring目录,并在其中创建spring-context.xml和spring-mvc.xml两个配置文件。
spring-context.xml:
xml
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
</bean>
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
</bean>
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
</bean>
spring-mvc.xml:
xml
<context:component-scan base-package="com.example.demo.controller"/>
<bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
</bean>
<mvc:default-servlet-handler/>
<mvc:annotation-driven/>
6. 编写实体类和Mapper接口
在src/main/java目录下创建com.example.demo.entity和com.example.demo.dao两个包。
在com.example.demo.entity包中创建一个User类,用于表示用户信息:
java
public class User {
private Integer id;
private String name;
private Integer age;
// 省略getter和setter方法
}
在com.example.demo.dao包中创建一个UserMapper接口,用于定义对User表的增删改查操作:
java
public interface UserMapper {
List<User> listAll();
User getById(Integer id);
void add(User user);
void update(User user);
void delete(Integer id);
}
7. 编写Mapper映射文件
在src/main/resources目录下创建mapper目录,并在其中创建UserMapper.xml文件,用于实现UserMapper接口中定义的操作:
xml
<mapper namespace="com.example.demo.dao.UserMapper">
<select id="listAll" resultType="com.example.demo.entity.User">
select * from user
</select>
<select id="getById" parameterType="java.lang.Integer" resultType="com.example.demo.entity.User">
select * from user where id = #{id}
</select>
<insert id="add" parameterType="com.example.demo.entity.User">
insert into user(name, age) values(#{name}, #{age})
</insert>
<update id="update" parameterType="com.example.demo.entity.User">
update user set name = #{name}, age = #{age} where id = #{id}
</update>
<delete id="delete" parameterType="java.lang.Integer">
delete from user where id = #{id}
</delete>
</mapper>
8. 编写Controller
在com.example.demo.controller包中创建一个UserController类,用于处理与用户相关的请求:
java
@Controller
@RequestMapping("/user")
public class UserController {
@Autowired
private UserMapper userMapper;
@RequestMapping("/list")
public String list(Model model) {
List<User> userList = userMapper.listAll();
model.addAttribute("userList", userList);
return "user/list";
}
@RequestMapping("/add")
public String add() {
return "user/add";
}
@RequestMapping("/doAdd")
public String doAdd(User user) {
userMapper.add(user);
return "redirect:/user/list";
}
@RequestMapping("/edit")
public String edit(Integer id, Model model) {
User user = userMapper.getById(id);
model.addAttribute("user", user);
return "user/edit";
}
@RequestMapping("/doEdit")
public String doEdit(User user) {
userMapper.update(user);
return "redirect:/user/list";
}
@RequestMapping("/delete")
public String delete(Integer id) {
userMapper.delete(id);
return "redirect:/user/list";
}
}
9. 编写JSP页面
在src/main/webapp/WEB-INF/views/user目录下创建list.jsp、add.jsp和edit.jsp三个文件,分别用于显示用户列表、添加用户和编辑用户:
list.jsp:
html
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<html>
<head>
<title>User List</title>
</head>
<body>
User List
ID
Name
Age
操作
<c:forEach items="${userList}" var="user">
${user.id}
${user.name}
${user.age}
编辑
删除
</c:forEach>
添加用户 </body> </html> add.jsp: html <%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head> <title>Add User</title> </head> <body> Add User <form action="${pageContext.request.contextPath}/user/doAdd" method="post"> Name: <input type="text" name="name"/>
Age: <input type="text" name="age"/>
<input type="submit" value="提交"/> </form> </body> </html> edit.jsp: html <%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head> <title>Edit User</title> </head> <body> Edit User <form action="${pageContext.request.contextPath}/user/doEdit" method="post"> <input type="hidden" name="id" value="${user.id}"/> Name: <input type="text" name="name" value="${user.name}"/>
Age: <input type="text" name="age" value="${user.age}"/>
<input type="submit" value="提交"/> </form> </body> </html> 10. 部署和运行 在IDEA中点击菜单栏的Run -> Edit Configurations,选择Tomcat Server,点击左侧的“+”按钮,选择Local,并设置Tomcat安装目录和应用访问路径。点击OK后,就可以选择新建的配置并点击Run按钮来启动Tomcat服务器。 启动成功后,打开浏览器,访问http://localhost:8080/SSM_Maven_Webapp/user/list即可看到用户列表页面。
添加用户 </body> </html> add.jsp: html <%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head> <title>Add User</title> </head> <body> Add User <form action="${pageContext.request.contextPath}/user/doAdd" method="post"> Name: <input type="text" name="name"/>
Age: <input type="text" name="age"/>
<input type="submit" value="提交"/> </form> </body> </html> edit.jsp: html <%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head> <title>Edit User</title> </head> <body> Edit User <form action="${pageContext.request.contextPath}/user/doEdit" method="post"> <input type="hidden" name="id" value="${user.id}"/> Name: <input type="text" name="name" value="${user.name}"/>
Age: <input type="text" name="age" value="${user.age}"/>
<input type="submit" value="提交"/> </form> </body> </html> 10. 部署和运行 在IDEA中点击菜单栏的Run -> Edit Configurations,选择Tomcat Server,点击左侧的“+”按钮,选择Local,并设置Tomcat安装目录和应用访问路径。点击OK后,就可以选择新建的配置并点击Run按钮来启动Tomcat服务器。 启动成功后,打开浏览器,访问http://localhost:8080/SSM_Maven_Webapp/user/list即可看到用户列表页面。









为了写一个基于IDEA、Java、JSP、MySQL和Tomcat的Web学生信息管理系统,你可以按照以下步骤进行:
1. 创建一个Maven项目,项目结构如下:
|--src
| |--main
| | |--java
| | | |--com.example.student
| | | | |--db // 数据库相关类
| | | | |--model // 实体类
| | | | |--servlet // Servlet类
| | | |--resources
| | | |--webapp // JSP页面和静态资源
| | |--webapp // Web资源
| |--test
| | |--java
|--pom.xml
2. 在MySQL中创建一个名为“student”的数据库,然后创建一个名为“students”的表,表结构如下:
CREATE TABLE students (
id INT PRIMARY KEY AUTO_INCREMENT,
name VARCHAR(50) NOT NULL,
gender VARCHAR(10) NOT NULL,
age INT NOT NULL,
major VARCHAR(50) NOT NULL,
grade INT NOT NULL
);
3. 在db包下创建一个名为“DBUtil”的工具类,用于连接数据库。代码如下:
java
package com.example.student.db;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
public class DBUtil {
private static final String URL = "jdbc:mysql://localhost:3306/student";
private static final String USER = "root";
private static final String PASSWORD = "root";
public static Connection getConnection() {
Connection conn = null;
try {
Class.forName("com.mysql.jdbc.Driver");
conn = DriverManager.getConnection(URL, USER, PASSWORD);
} catch (ClassNotFoundException | SQLException e) {
e.printStackTrace();
}
return conn;
}
}
4. 在model包下创建一个名为“Student”的实体类,代码如下:
java
package com.example.student.model;
public class Student {
private int id;
private String name;
private String gender;
private int age;
private String major;
private int grade;
public Student() {
}
public Student(int id, String name, String gender, int age, String major, int grade) {
this.id = id;
this.name = name;
this.gender = gender;
this.age = age;
this.major = major;
this.grade = grade;
}
// getter和setter方法省略
}
5. 在servlet包下创建一个名为“StudentServlet”的Servlet类,用于处理前端传来的请求。代码如下:
java
package com.example.student.servlet;
import com.example.student.db.DBUtil;
import com.example.student.model.Student;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.sql.*;
import java.util.ArrayList;
import java.util.List;
@WebServlet(name = "StudentServlet", urlPatterns = "/student")
public class StudentServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
String action = req.getParameter("action");
if ("add".equals(action)) {
// 处理学生信息添加请求
String name = req.getParameter("name");
String gender = req.getParameter("gender");
int age = Integer.parseInt(req.getParameter("age"));
String major = req.getParameter("major");
int grade = Integer.parseInt(req.getParameter("grade"));
Student student = new Student(0, name, gender, age, major, grade);
addStudent(student);
resp.sendRedirect(req.getContextPath() + "/student");
} else if ("edit".equals(action)) {
// 处理学生信息编辑请求
int id = Integer.parseInt(req.getParameter("id"));
String name = req.getParameter("name");
String gender = req.getParameter("gender");
int age = Integer.parseInt(req.getParameter("age"));
String major = req.getParameter("major");
int grade = Integer.parseInt(req.getParameter("grade"));
Student student = new Student(id, name, gender, age, major, grade);
updateStudent(student);
resp.sendRedirect(req.getContextPath() + "/student");
} else if ("delete".equals(action)) {
// 处理学生信息删除请求
int id = Integer.parseInt(req.getParameter("id"));
deleteStudent(id);
resp.sendRedirect(req.getContextPath() + "/student");
} else {
// 处理学生信息列表请求
List<Student> students = getAllStudents();
req.setAttribute("students", students);
req.getRequestDispatcher("/WEB-INF/views/student.jsp").forward(req, resp);
}
}
private List<Student> getAllStudents() {
List<Student> students = new ArrayList<>();
try (Connection conn = DBUtil.getConnection();
Statement stmt = conn.createStatement()) {
String sql = "SELECT * FROM students";
ResultSet rs = stmt.executeQuery(sql);
while (rs.next()) {
int id = rs.getInt("id");
String name = rs.getString("name");
String gender = rs.getString("gender");
int age = rs.getInt("age");
String major = rs.getString("major");
int grade = rs.getInt("grade");
Student student = new Student(id, name, gender, age, major, grade);
students.add(student);
}
} catch (SQLException e) {
e.printStackTrace();
}
return students;
}
private void addStudent(Student student) {
try (Connection conn = DBUtil.getConnection();
PreparedStatement stmt = conn.prepareStatement("INSERT INTO students (name, gender, age, major, grade) VALUES (?, ?, ?, ?, ?)")) {
stmt.setString(1, student.getName());
stmt.setString(2, student.getGender());
stmt.setInt(3, student.getAge());
stmt.setString(4, student.getMajor());
stmt.setInt(5, student.getGrade());
stmt.executeUpdate();
} catch (SQLException e) {
e.printStackTrace();
}
}
private void updateStudent(Student student) {
try (Connection conn = DBUtil.getConnection();
PreparedStatement stmt = conn.prepareStatement("UPDATE students SET name=?, gender=?, age=?, major=?, grade=? WHERE id=?")) {
stmt.setString(1, student.getName());
stmt.setString(2, student.getGender());
stmt.setInt(3, student.getAge());
stmt.setString(4, student.getMajor());
stmt.setInt(5, student.getGrade());
stmt.setInt(6, student.getId());
stmt.executeUpdate();
} catch (SQLException e) {
e.printStackTrace();
}
}
private void deleteStudent(int id) {
try (Connection conn = DBUtil.getConnection();
PreparedStatement stmt = conn.prepareStatement("DELETE FROM students WHERE id=?")) {
stmt.setInt(1, id);
stmt.executeUpdate();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
6. 在webapp目录下创建一个名为“student.jsp”的JSP页面,用于显示学生信息列表和处理学生信息的添加、编辑和删除等操作。代码如下:
html
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>学生信息管理系统</title>
</head>
<body>
学生信息管理系统
ID
姓名
性别
年龄
专业
年级
操作
<c:forEach items="${students}" var="student">
${student.id}
${student.name}
${student.gender}
${student.age}
${student.major}
${student.grade}
编辑
删除
</c:forEach>
添加学生信息
<form method="post" action="${pageContext.request.contextPath}/student?action=add">
<label for="name">姓名:</label>
<input type="text" id="name" name="name" required>
<label for="gender">性别:</label>
<input type="radio" id="gender" name="gender" value="男" required>男
<input type="radio" id="gender" name="gender" value="女" required>女
<label for="age">年龄:</label>
<input type="number" id="age" name="age" required>
<label for="major">专业:</label>
<input type="text" id="major" name="major" required>
<label for="grade">年级:</label>
<input type="number" id="grade" name="grade" required>
<button type="submit">添加</button>
</form>
<c:if test="${not empty param.id}">
编辑学生信息
<form method="post" action="${pageContext.request.contextPath}/student?action=edit&id=${param.id}">
<label for="name">姓名:</label>
<input type="text" id="name" name="name" value="${student.name}" required>
<label for="gender">性别:</label>
<input type="radio" id="gender" name="gender" value="男" ${student.gender=='男'?'checked':''} required>男
<input type="radio" id="gender" name="gender" value="女" ${student.gender=='女'?'checked':''} required>女
<label for="age">年龄:</label>
<input type="number" id="age" name="age" value="${student.age}" required>
<label for="major">专业:</label>
<input type="text" id="major" name="major" value="${student.major}" required>
<label for="grade">年级:</label>
<input type="number" id="grade" name="grade" value="${student.grade}" required>
<button type="submit">保存</button>
</form>
</c:if>
</body>
</html>
7. 在pom.xml文件中添加以下依赖:
xml
<dependencies>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>4.0.1</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>jstl</groupId>
<artifactId>jstl</artifactId>
<version>1.2</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.26</version>
</dependency>
</dependencies>
8. 在Tomcat中部署该项目,启动Tomcat服务,通过浏览器访问项目的根路径,即可看到学生信息管理系统的页面。
以上是一个基本的实现过程,具体实现过程中还需要根据实际情况进行相应的调整和优化。


