运行效果:

注册登陆界面

注册存在的账户时

登陆之后主界面如下

点击图书管理-图书更新界面如下

图书列表

项目说明:

由于平时工作比较忙,也没时间写,可是我在公众号后台看见好多小伙伴讨论,我就抽时间写个当作参考。本系统界面我个人就从简设计了,本来打算使用windowbuilder插件设计的,可想到使用windowbuilder插件之后导致代码冗余,会影响到代码可读性,可能对小白不友好。虽然界面设计简单,但是功能上我会尽量想着写全,当然对于页面你可以增加自己的设计,比如增加一个背景图片等,网上都有指导,对于界面美观度从简了。

关键代码:

用户登陆

package bookmanage.dao;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException; import bookmanage.model.User;
import bookmanage.utils.DbUtil; /**
* @Description 连接数据库工具类
* @author com.javayihao.top
*/
public class UserDao {
/**
* 根据用户账号查询用户
*
* @param accout
* 入参:用户账号
* @return 查找的用户
*/
public User getUserByAccout(String accout) {
Connection connection = DbUtil.getConnection();
String sql = "select accout,pass from t_user where accout=?";
try {
PreparedStatement ps = connection.prepareStatement(sql);
ps.setString(1, accout);
ResultSet rs = ps.executeQuery();
if (rs.next()) {// 存在用户,封装用户返回
User user = new User(rs.getString("accout"), rs.getString("pass"));
DbUtil.close(connection, ps);// 关闭连接
return user;
}
} catch (SQLException e) {
e.printStackTrace();
}
return null;
} public boolean insertUser(User user) {
Connection connection = DbUtil.getConnection();// 获得数据库连接对象
String sql = "insert into t_user(accout,pass)values(?,?)";
try {
PreparedStatement ps = connection.prepareStatement(sql);
ps.setString(1, user.getAccout());
ps.setString(2, user.getPass());
if (!ps.execute()) {// 成功
DbUtil.close(connection, ps);// 关闭连接
return true;
}
} catch (SQLException e) {
e.printStackTrace();
}
return false;// 失败
}
}

图书更新

package bookmanage.view;

import java.awt.GridLayout;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener; import javax.swing.JButton;
import javax.swing.JLabel;
import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.JTextField; import bookmanage.dao.BookDao;
import bookmanage.model.Book; /**
* @Description 用于图书增删改查面板
* @author com.javayihao.top
*/
public class CrudBookPanel extends JPanel implements ActionListener {
// 定义首页按钮、图书列表按钮、 其他功能按钮,增加图书、删除图书、修改图书、查询图书
private JButton addBtn, deleteBtn, updateBtn, findBtn;
// 定义标签 底部信息标签、 图书编号、 图书名称、 图书数量、 图书价格
private JLabel idLabel, nameLabel, numLabel, priceLabel;
// 定义图书编号、 名称、 数量、 价格文本框
private JTextField idJTextField, nameJTextField, numJTextField, priceJTextField;
// 定义文本对象
private String bookIdText;
private String bookNameText;
private String bookNumText;
private String bookPriceText;
// 图书数量和价格
private Integer numBook;
private Float priceBook;
// 定义对象BookDao
private BookDao bookDao; public CrudBookPanel() {
bookDao = new BookDao();//实例化图书操作对象
// 实例化增删改查按钮
addBtn = new JButton("增加图书");
addBtn.addActionListener(this);// 设置图书增加按钮监听
addBtn.setActionCommand("addbook");
deleteBtn = new JButton("删除图书");
deleteBtn.addActionListener(this);// 设置图书删除按钮监听
deleteBtn.setActionCommand("deletebook");
updateBtn = new JButton("修改图书");
updateBtn.addActionListener(this);// 设置图书修改按钮监听
updateBtn.setActionCommand("updatebook");
findBtn = new JButton("查询图书");
findBtn.addActionListener(this);// 设置图书查询按钮监听
findBtn.setActionCommand("findbook");
// 实例化图书编号 名称 数量 价格标签
idLabel = new JLabel("图书编号");
nameLabel = new JLabel("图书名称");
priceLabel = new JLabel("图书价格");
numLabel = new JLabel("图书数量");
// 实例化文本框
idJTextField = new JTextField(12);
nameJTextField = new JTextField(12);
numJTextField = new JTextField(12);
priceJTextField = new JTextField(12);
this.setLayout(new GridLayout(6, 2, 2, 2));
// 给增删改查面板添加图书编号 名称 数量 价格标签以及文本框
this.add(idLabel);
this.add(idJTextField);
this.add(nameLabel);
this.add(nameJTextField);
this.add(priceLabel);
this.add(priceJTextField);
this.add(numLabel);
this.add(numJTextField);
// 给增删改查面板添加图书编号 名称 数量 价格按钮
this.add(addBtn);
this.add(deleteBtn);
this.add(updateBtn);
this.add(findBtn);
} @Override
public void actionPerformed(ActionEvent e) {
if (e.getActionCommand().equals("addbook")) {// 添加图书
addbook();
} else if (e.getActionCommand().equals("deletebook")) {// 删除图书
deleteBook();
} else if (e.getActionCommand().equals("updatebook")) {// 修改图书
updateBook();
} else if (e.getActionCommand().equals("findbook")) {// 查询图书
findBook();
}
} /**
* 查询图书
*/
private void findBook() {
bookIdText = idJTextField.getText().trim().toString();
Book book = bookDao.getBookById(bookIdText);
if (bookIdText.equals("")) {
JOptionPane.showMessageDialog(this, "图书编号不能为空");
} else if (book != null) {// 当前输入的图书编号存在
try {
nameJTextField.setText(book.getName());// 填充图书名称文本框
numJTextField.setText(book.getNum() + "");// 将数字类型转成字符串并填充文本框
priceJTextField.setText(book.getPrice() + "");// 将数字类型转成字符串并填充文本框
} catch (Exception e) {
JOptionPane.showMessageDialog(this, "图书查询异常 请联系管理员");
}
} else {
JOptionPane.showMessageDialog(this, "图书不存在");
} } /**
* 修改图书
*/
private void updateBook() {
bookIdText = idJTextField.getText().trim().toString();
bookNameText = nameJTextField.getText().trim().toString();
bookNumText = numJTextField.getText().trim().toString();
bookPriceText = priceJTextField.getText().trim().toString();
if (bookIdText.equals("")) {
JOptionPane.showMessageDialog(this, "图书编号不能为空");
} else if (bookNameText.equals("")) {
JOptionPane.showMessageDialog(this, "图书名称不能为空");
} else if (bookNumText.equals("")) {
JOptionPane.showMessageDialog(this, "图书数量不能为空");
} else if (bookPriceText.equals("")) {
JOptionPane.showMessageDialog(this, "图书价格不能为空");
} else {
// 将图书数量和图书价格转成对应的数字类型
if (bookDao.getBookById(bookIdText) == null) {// 图书不存在
JOptionPane.showMessageDialog(this, "输入正确的图书编号");
} else {
try {
numBook = Integer.parseInt(bookNumText);
priceBook = Float.parseFloat(bookPriceText);
bookDao.updateBook(new Book(bookIdText, bookNameText, numBook, priceBook));
JOptionPane.showMessageDialog(this, "图书修改成功");
} catch (Exception e) {
JOptionPane.showMessageDialog(this, "输入正确的图书数量和价格");
e.printStackTrace();
}
}
} } /**
* 删除图书
*/
private void deleteBook() {
bookIdText = idJTextField.getText().trim().toString();
if (bookIdText.equals("")) {
JOptionPane.showMessageDialog(this, "图书编号不能为空");
} else if (bookDao.getBookById(bookIdText) != null) {// 当前输入的图书编号是否存在
try {
bookDao.deleteBootByid(bookIdText);
JOptionPane.showMessageDialog(this, "图书删除成功");
} catch (Exception e) {
JOptionPane.showMessageDialog(this, "图书删除异常 请联系管理员");
}
} else {
JOptionPane.showMessageDialog(this, "图书不存在");
} } /**
* 增加图书
*/
private void addbook() {
bookIdText = idJTextField.getText().trim().toString();
bookNameText = nameJTextField.getText().trim().toString();
bookNumText = numJTextField.getText().trim().toString();
bookPriceText = priceJTextField.getText().trim().toString();
if (bookIdText.equals("")) {
JOptionPane.showMessageDialog(this, "图书编号不能为空");
} else if (bookNameText.equals("")) {
JOptionPane.showMessageDialog(this, "图书名称不能为空");
} else if (bookNumText.equals("")) {
JOptionPane.showMessageDialog(this, "图书数量不能为空");
} else if (bookPriceText.equals("")) {
JOptionPane.showMessageDialog(this, "图书价格不能为空");
} else {
// 将图书数量和图书价格转成对应的数字类型
if (bookDao.getBookById(bookIdText) != null) {// 编号重复
JOptionPane.showMessageDialog(this, "图书编号重复");
} else {
try {
numBook = Integer.parseInt(bookNumText);
priceBook = Float.parseFloat(bookPriceText);
bookDao.insertBoot(new Book(bookIdText, bookNameText, numBook, priceBook));
JOptionPane.showMessageDialog(this, "图书增加成功");
} catch (Exception e) {
JOptionPane.showMessageDialog(this, "输入正确的图书数量和价格");
e.printStackTrace();
}
}
} }
}

图书列表

package bookmanage.view;

import java.awt.BorderLayout;
import java.util.ArrayList;
import java.util.Vector; import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTable; import bookmanage.dao.BookDao;
import bookmanage.model.Book; /**
* 自定义图书列表面板
* @author com.javayihao.top
*/
public class ListPanel extends JPanel {
// 从数据库中取出信息
// rowData用来存放行数据
// columnNames存放列名
Vector rowData, columnNames;
JTable jt = null;
JScrollPane jsp = null; // 构造函数
public ListPanel() {
ArrayList<Book> books = new BookDao().getBookList();
columnNames = new Vector();
// 设置列名
columnNames.add("图书编号");
columnNames.add("图书名称");
columnNames.add("图书价格");
columnNames.add("图书数量");
rowData = new Vector();
for (int i = 0; i < books.size(); i++) {
//实例化每一行数据
Vector hang = new Vector();
hang.add(books.get(i).getId());
hang.add(books.get(i).getName());
hang.add(books.get(i).getPrice());
hang.add(books.get(i).getNum());
// 加入到rowData
rowData.add(hang);
}
// 初始化Jtable
jt = new JTable(rowData, columnNames);
// 初始化 jsp
jsp = new JScrollPane(jt);
this.add(jsp);
}
}

数据库

/*
Navicat MySQL Data Transfer Source Server : localhost
Source Server Version : 50527
Source Host : localhost:3306
Source Database : db_book Target Server Type : MYSQL
Target Server Version : 50527
File Encoding : 65001 Date: 2019-12-23 13:01:43
*/ SET FOREIGN_KEY_CHECKS=0; -- ----------------------------
-- Table structure for t_book
-- ----------------------------
DROP TABLE IF EXISTS `t_book`;
CREATE TABLE `t_book` (
`id` varchar(20) NOT NULL,
`name` varchar(255) NOT NULL,
`num` int(11) NOT NULL,
`price` float(10,2) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8; -- ----------------------------
-- Records of t_book
-- ----------------------------
INSERT INTO `t_book` VALUES ('123456', 'java入门到精通', '100', '22.00');
INSERT INTO `t_book` VALUES ('123457', 'c++实战', '100', '50.00');
INSERT INTO `t_book` VALUES ('123458', '微服务电商实战', '22', '1.00'); -- ----------------------------
-- Table structure for t_user
-- ----------------------------
DROP TABLE IF EXISTS `t_user`;
CREATE TABLE `t_user` (
`accout` varchar(255) NOT NULL,
`pass` varchar(255) NOT NULL,
PRIMARY KEY (`accout`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8; -- ----------------------------
-- Records of t_user
-- ----------------------------
INSERT INTO `t_user` VALUES ('123', '123');
INSERT INTO `t_user` VALUES ('123456', '123456');
INSERT INTO `t_user` VALUES ('1234567', '123456');
INSERT INTO `t_user` VALUES ('admin', 'admin');
INSERT INTO `t_user` VALUES ('dsfasdfa', 'afasdf');
INSERT INTO `t_user` VALUES ('fdsaf', 'adfas');

源码获取:

本来打算放在github上的,考虑到许多小伙伴不会用github,就放在我个人公众号,关注公众号 程序三两行 回复 “图书” 即可

如何运行:

1. 先说下运行环境吧,java+eclipse+mysql,所以首先java环境得有,本地安装了mysql数据库,关于数据库图形化界面工具我用得是navicat;

2. 创建数据库db_book,在获取代码文件中有个db_book.sql文件,记事本打开复制到刚才创建得db_book数据库直接查询运行即可

3. 打开eclipse

点击运行

有问题可以联系  公众号   程序三两行

java图书管理系统(桌面版本)的更多相关文章

  1. JAVA图书管理系统汇总共27个

    好多人都在搜索图书管理系统,感觉这个挺受欢迎的,所以整理了一系列的图书管理系统,让大家选择.java图书馆管理系统[优秀毕业设计论文+源码]http://down.51cto.com/data/683 ...

  2. JAVA图书管理系统汇总共27个[转]

    java图书馆管理系统[优秀毕业设计论文+源码]http://down.51cto.com/data/68350java+sql server图书管理系统 http://down.51cto.com/ ...

  3. Java图书管理系统(用Java常用集合实现)

    图书管理系统 一.需求说明 1.功能:登录,注册,忘记密码,管理员管理,图书管理. 2.管理员管理:管理员的增删改查. 3.图书管理:图书的增删改查. 4.管理员属性包括:id,姓名,性别,年龄,家庭 ...

  4. 随笔:Oracle实验课(软件系统开发综合实践)B/S结构;java——图书管理系统

    以上是我需要注意的要求 -------------------------------此处为放假分割线-1-20----------------------------------- 初步完成了整个程 ...

  5. 汇文Libsys图书管理系统全版本权限绕过+getshell

    由于一个很低级的代码错误,导致可以登录Libsys任意图书系统后台,并且由于代码未做过滤可直接getshell. 该图书管理系统的用户量很大,全国很大一部分院校都在使用此系统.经测试3.5-5.0版本 ...

  6. 图书管理系统总结——JAVA Swing控件简介

    断断续续学习JAVA语言,写了一个多月数据库大作业,终于在五一过后写完了.由于第一次使用JAVA和数据库,遇到了许多问题,记录下来,以备以后查看. 我使用的JAVA SE,说实话,在开发后期,觉得JA ...

  7. 基于Java swing+mysql+eclipse的【图书管理系统】

    本项目为Java swing项目,在工作环境中基本使用不到,但是很多学校把这个当做编程入门的项目来做,故分享出本项目供初学者参考. CSDN赞助下载:https://download.csdn.net ...

  8. 《图书管理系统——java》

    /* (程序头部凝视開始) * 程序的版权和版本号声明部分 * Copyright (c) 2011, 烟台大学计算机学院学生 * All rights reserved. * 文件名:    < ...

  9. java web 项目 图书管理系统的设计与实现

     java web 项目 图书管理系统的设计与实现

  10. 基于Java SE集合的图书管理系统

    图书管理系统一.需求说明1.功能:登录,注册,忘记密码,管理员管理,图书管理.2.管理员管理:管理员的增删改查.3.图书管理:图书的增删改查.4.管理员属性包括:id,姓名,性别,年龄,家庭住址,手机 ...

随机推荐

  1. [转帖] Linux命令拾遗-使用blktrace分析io情况

    https://www.cnblogs.com/codelogs/p/16060775.html 原创:打码日记(微信公众号ID:codelogs),欢迎分享,转载请保留出处. 简介# 一般来说,想检 ...

  2. 【转帖】3.JVM内存结构概述

    目录 1.JVM内存结构 1.JVM内存结构 在JVM系列的第一篇文章中已经给出了JVM内存结构的简图,下面是JVM内存结构更加详细的图. 同样,JVM的内存结构可以分为上中下3层. 上层主要是类加载 ...

  3. 最简单的以CentOS为base images 安装 Nodejs等操作的方法

    镜像内安装NodeJS的简单方法 公司内有产品需要安装nodejs以便进行相关操作,Linux和Windows时没有问题,但是如果是镜像的话可能会稍微复杂一点, 这里简单进行一下总结, 以便备忘. 1 ...

  4. 大模型应用开发:为产品创建一个AI客服/智能助手

    欢迎阅读本系列文章!我将带你一起探索如何使用OpenAI API来开发GPT应用.无论你是编程新手还是资深开发者,都能在这里获得灵感和收获. 本文将继续展示AI助手的开发方式,在OpenAPI中它的名 ...

  5. docker上部署启动RabbitMQ

    在docker上部署启动RabbitMQ及使用 一.docker上部署启动RabbitMQ 1.查询rabbitmq镜像 docker search rabbitmq:management 2.拉取r ...

  6. Fabric网络升级(三)

    原文来自这里. 如果不熟悉capability,那么操作前可以查阅Capabilities.需要注意的是在启用capabilities前,需要升级归属该通道的peer节点和排序节点. 更多关于最新版F ...

  7. HTMl插入视频背景

    插入视频背景一段简单的css即可 首先定义HTML的video标签 <video src="视频路径" class="bjimg" autoplay lo ...

  8. 5.12 汇编语言:仿写While循环语句

    循环语句(While)一种基本控制结构,它允许程序在条件为真的情况下重复执行一段代码块,直到条件为假为止.循环语句在处理需要重复执行的任务时非常有用,它可以让程序更加高效地处理大量数据或者重复性操作. ...

  9. SpringBoot 整合多数据源的事务问题

    代码 先贴代码: 核心就是:Spring给我们提供的一个类 AbstractRoutingDataSource,然后我们再写一个切面来切换数据源,肯定要有一个地方存储key还要保证上下文都可用,所以我 ...

  10. 教你用JavaScript实现调皮的字母

    案例介绍 欢迎来到我的小院,我是霍大侠,恭喜你今天又要进步一点点了!我们来用JavaScript编程实战案例,制作提高打字速度的小游戏-调皮的字母.点击与屏幕上字母相对应的按键,若按键与出现的字母一致 ...