最全IDEA+Java+JSP+Mysql+Tomcat实现Web学校教材管理系统(1),java开发面试简历模板java

难道这样就够了吗?不,远远不够!

提前多熟悉阿里往年的面试题肯定是对面试有很大的帮助的,但是作为技术性职业,手里有实打实的技术才是你面对面试官最有用的利器,这是从内在散发出来的自信。

备战阿里时我花的最多的时间就是在学习技术上,占了我所有学习计划中的百分之70,这是一些我学习期间觉得还是很不错的一些学习笔记

我为什么要写这篇文章呢,其实我觉得学习是不能停下脚步的,在网络上和大家一起分享,一起讨论,不单单可以遇到更多一样的人,还可以扩大自己的眼界,学习到更多的技术,我还会在csdn、博客、掘金等网站上分享技术,这也是一种学习的方法。

今天就分享到这里了,谢谢大家的关注,以后会分享更多的干货给大家!

阿里一面就落马,恶补完这份“阿里面试宝典”后,上岸蚂蚁金服

阿里一面就落马,恶补完这份“阿里面试宝典”后,上岸蚂蚁金服

image.png

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

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

1.开发环境

2.技术选型

3.系统功能

4.数据库文件

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”/>

新增教材


返回上一级


添加

重置

  • 8
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值