Java最新IDEA+Java+JSP+Mysql+Tomcat实现Web学校教材管理系统,腾讯、阿里Java高级面试真题汇总

最近我根据上述的技术体系图搜集了几十套腾讯、头条、阿里、美团等公司21年的面试题,把技术点整理成了视频(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,这里以图片的形式给大家展示一部分

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

5.系统截图

二、系统展示

1.登录系统

2.系统主页

3.新增教材

4.修改教材

三、部分代码

AdminDaoImpl

MaterialDaoImpl

material-add.jsp

material-add-do.jsp

material-update.jsp

material-update-do.jsp

四、其他

1.更多系统

Java+JSP系统系列实现

Java+Servlet系统系列实现

Java+SSM系统系列实现

Java+SSH系统系列实现

Java+Springboot系统系列实现

2.源码下载

3.运行项目

4.备注

5.支持博主


一、系统介绍

======

1.开发环境


开发工具:IDEA2018

JDK版本:Jdk1.8

Mysql版本:8.0.13

2.技术选型


Java+Jsp+Mysql

3.系统功能


1.登录系统;

2.管理员对学校教材的增删改查。

4.数据库文件


/*

Navicat Premium Data Transfer

Source Server : MYSQL

Source Server Type : MySQL

Source Server Version : 80013

Source Host : localhost:3306

Source Schema : jsp_teach_material

Target Server Type : MySQL

Target Server Version : 80013

File Encoding : 65001

Date: 03/03/2022 17:04:24

*/

SET NAMES utf8mb4;

SET FOREIGN_KEY_CHECKS = 0;


– Table structure for admin


DROP TABLE IF EXISTS admin;

CREATE TABLE admin (

username varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL,

password varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL

) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci ROW_FORMAT = DYNAMIC;


– Records of admin


INSERT INTO admin VALUES (‘admin’, ‘admin’);


– Table structure for material


DROP TABLE IF EXISTS material;

CREATE TABLE material (

id int(11) NOT NULL,

name varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL,

author varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL,

publish varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL,

number varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL

) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci ROW_FORMAT = Dynamic;


– Records of material


INSERT INTO material VALUES (1001, ‘语文’, ‘张三’, ‘人民日报出版社’, ‘900’);

INSERT INTO material VALUES (1002, ‘数学’, ‘李四’, ‘人民日报出版社’, ‘1000’);

INSERT INTO material VALUES (1003, ‘英语’, ‘王五’, ‘人民日报出版社’, ‘1500’);

INSERT INTO material VALUES (1004, ‘赵六’, ‘黄七’, ‘人民日报出版社’, ‘2000’);

SET FOREIGN_KEY_CHECKS = 1;

5.系统截图


二、系统展示

======

1.登录系统


2.系统主页



3.新增教材



4.修改教材


三、部分代码

=======

AdminDaoImpl


package com.sjsq.dao.impl;

import com.sjsq.dao.AdminDao;

import com.sjsq.utils.DBUtil;

import com.sjsq.entity.Admin;

import java.sql.Connection;

import java.sql.PreparedStatement;

import java.sql.ResultSet;

import java.sql.SQLException;

/**

  • @author: shuijianshiqing

  • @date: 2022-03-01

  • @description: 登录系统实现

*/

public class AdminDaoImpl implements AdminDao {

/**

  • 登录系统

  • @param admin

  • @return

*/

@Override

public Admin login(Admin admin) {

Connection con = null;

PreparedStatement ps = null;

ResultSet rs = null;

try {

// 1.获取数据库连接

con = DBUtil.getConnection();

// 2.写sql

String sql = “select * from admin where username = ? and password = ?”;

// 3.预编译

ps = con.prepareStatement(sql);

// 4.设置值

ps.setObject(1, admin.getUsername());

ps.setObject(2, admin.getPassword());

rs = ps.executeQuery();

Admin adminLogin = null;

if (rs.next()) {

adminLogin = new Admin();

// 从数据库中获取值到实体类的setter方法中

adminLogin.setUsername(rs.getString(“username”));

adminLogin.setPassword(rs.getString(“password”));

// 返回的是你查询出来的完整的对象

return adminLogin;

}

} catch (ClassNotFoundException e) {

e.printStackTrace();

} catch (SQLException e) {

e.printStackTrace();

} finally {

// 关闭资源,避免出现异常

DBUtil.close(con, ps, rs);

}

return null;

}

}

MaterialDaoImpl


package com.sjsq.dao.impl;

import com.sjsq.dao.MaterialDao;

import com.sjsq.entity.Material;

import com.sjsq.utils.DBUtil;

import java.sql.Connection;

import java.sql.PreparedStatement;

import java.sql.ResultSet;

import java.sql.SQLException;

import java.util.ArrayList;

import java.util.List;

/**

  • @author: shuijianshiqing

  • @date: 2022-03-03

  • @description:

*/

public class MaterialDaoImpl implements MaterialDao {

@Override

public List selectAll(String sql, Object[] arr) {

Connection con = null;

PreparedStatement ps = null;

ResultSet rs = null;

try {

// 1.连接数据库

con = DBUtil.getConnection();

// 2.预编译

ps = con.prepareStatement(sql);

if (arr != null) {

for (int i = 0; i < arr.length; i++) {

// 传入sql的参数,向上转型,某个栏位的查询

ps.setObject(i + 1, arr[i]);

}

}

// 3.执行sql

rs = ps.executeQuery();

// 4.保存查询出来的数据到list

List list = new ArrayList<>();

while (rs.next()) {

Material material = new Material();

material.setId(rs.getInt(“id”));

material.setName(rs.getString(“name”));

material.setAuthor(rs.getString(“author”));

material.setPublish(rs.getString(“publish”));

material.setNumberr(rs.getString(“number”));

list.add(material);

}

return list;

} catch (Exception e) {

e.printStackTrace();

} finally {

// 关闭链接,避免数据库连接过多

DBUtil.close(con, ps, rs);

}

return null;

}

@Override

public Material selectMaterial(Integer id) {

Connection con = null;

PreparedStatement ps = null;

ResultSet rs = null;

try {

// 1.连接数据库

con = DBUtil.getConnection();

// 2.预编译

String sql = “select * from material where id = ?”;

ps = con.prepareStatement(sql);

ps.setInt(1, id);

// 3.执行sql

rs = ps.executeQuery();

while (rs.next()) {

Material material = new Material();

material.setId(rs.getInt(“id”));

material.setName(rs.getString(“name”));

material.setAuthor(rs.getString(“author”));

material.setPublish(rs.getString(“publish”));

material.setNumberr(rs.getString(“number”));

return material;

}

} catch (ClassNotFoundException e) {

e.printStackTrace();

} catch (SQLException e) {

e.printStackTrace();

} finally {

// 关闭资源,避免出现异常

DBUtil.close(con, ps, rs);

}

return null;

}

@Override

public boolean addMaterial(Material material) {

String sql = “insert into material values (?,?,?,?,?)”;

List list = new ArrayList();

list.add(material.getId());

list.add(material.getName());

list.add(material.getAuthor());

list.add(material.getPublish());

list.add(material.getNumber());

boolean flag = DBUtil.addUpdateDelete(sql, list.toArray());

if (flag) {

return true;

} else {

return false;

}

}

@Override

public boolean updateMaterial(Material material) {

String sql = “update material set name=?,author=?,publish=?,number=? where id=?”;

List list = new ArrayList();

list.add(material.getName());

list.add(material.getAuthor());

list.add(material.getPublish());

list.add(material.getNumber());

// 注意id在最后面

list.add(material.getId());

boolean flag = DBUtil.addUpdateDelete(sql, list.toArray());

if (flag) {

return true;

} else {

return false;

}

}

@Override

public boolean deleteMaterial(Integer id) {

String sql = “delete from material where id=?”;

List list = new ArrayList();

list.add(id);

boolean flag = DBUtil.addUpdateDelete(sql, list.toArray());

if (flag) {

return true;

} else {

return false;

}

}

}

material-add.jsp


<%@ page contentType=“text/html;charset=UTF-8” language=“java” %>

新增教材

<%-- 头部 --%>

<jsp:include page=“top.jsp”/>

新增教材


返回上一级


添加

重置

<%-- 底部 --%>

<jsp:include page=“bottom.jsp”/>

分享

首先分享一份学习大纲,内容较多,涵盖了互联网行业所有的流行以及核心技术,以截图形式分享:

(亿级流量性能调优实战+一线大厂分布式实战+架构师筑基必备技能+设计思想开源框架解读+性能直线提升架构技术+高效存储让项目性能起飞+分布式扩展到微服务架构…实在是太多了)

其次分享一些技术知识,以截图形式分享一部分:

Tomcat架构解析:

算法训练+高分宝典:

Spring Cloud+Docker微服务实战:

最后分享一波面试资料:

切莫死记硬背,小心面试官直接让你出门右拐

1000道互联网Java面试题:

Java高级架构面试知识整理:

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

us();

return false;

} else if (name == “” || name == null) {

alert(“请输入教材名称”);

addForm.name.focus();

return false;

}

return true;

}

<%-- 底部 --%>

<jsp:include page=“bottom.jsp”/>

分享

首先分享一份学习大纲,内容较多,涵盖了互联网行业所有的流行以及核心技术,以截图形式分享:

(亿级流量性能调优实战+一线大厂分布式实战+架构师筑基必备技能+设计思想开源框架解读+性能直线提升架构技术+高效存储让项目性能起飞+分布式扩展到微服务架构…实在是太多了)

其次分享一些技术知识,以截图形式分享一部分:

Tomcat架构解析:

[外链图片转存中…(img-I7kAxnLI-1715369545292)]

算法训练+高分宝典:

[外链图片转存中…(img-cNPiemAq-1715369545292)]

Spring Cloud+Docker微服务实战:

[外链图片转存中…(img-usBh0ygM-1715369545292)]

最后分享一波面试资料:

切莫死记硬背,小心面试官直接让你出门右拐

1000道互联网Java面试题:

[外链图片转存中…(img-hjtCg4zI-1715369545293)]

Java高级架构面试知识整理:

[外链图片转存中…(img-YN9yD3SQ-1715369545293)]

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

  • 26
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值