java图书管理系统(桌面版本)
运行效果:
注册登陆界面
注册存在的账户时
登陆之后主界面如下
点击图书管理-图书更新界面如下
图书列表
项目说明:
由于平时工作比较忙,也没时间写,可是我在公众号后台看见好多小伙伴讨论,我就抽时间写个当作参考。本系统界面我个人就从简设计了,本来打算使用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图书管理系统(桌面版本)的更多相关文章
- JAVA图书管理系统汇总共27个
好多人都在搜索图书管理系统,感觉这个挺受欢迎的,所以整理了一系列的图书管理系统,让大家选择.java图书馆管理系统[优秀毕业设计论文+源码]http://down.51cto.com/data/683 ...
- JAVA图书管理系统汇总共27个[转]
java图书馆管理系统[优秀毕业设计论文+源码]http://down.51cto.com/data/68350java+sql server图书管理系统 http://down.51cto.com/ ...
- Java图书管理系统(用Java常用集合实现)
图书管理系统 一.需求说明 1.功能:登录,注册,忘记密码,管理员管理,图书管理. 2.管理员管理:管理员的增删改查. 3.图书管理:图书的增删改查. 4.管理员属性包括:id,姓名,性别,年龄,家庭 ...
- 随笔:Oracle实验课(软件系统开发综合实践)B/S结构;java——图书管理系统
以上是我需要注意的要求 -------------------------------此处为放假分割线-1-20----------------------------------- 初步完成了整个程 ...
- 汇文Libsys图书管理系统全版本权限绕过+getshell
由于一个很低级的代码错误,导致可以登录Libsys任意图书系统后台,并且由于代码未做过滤可直接getshell. 该图书管理系统的用户量很大,全国很大一部分院校都在使用此系统.经测试3.5-5.0版本 ...
- 图书管理系统总结——JAVA Swing控件简介
断断续续学习JAVA语言,写了一个多月数据库大作业,终于在五一过后写完了.由于第一次使用JAVA和数据库,遇到了许多问题,记录下来,以备以后查看. 我使用的JAVA SE,说实话,在开发后期,觉得JA ...
- 基于Java swing+mysql+eclipse的【图书管理系统】
本项目为Java swing项目,在工作环境中基本使用不到,但是很多学校把这个当做编程入门的项目来做,故分享出本项目供初学者参考. CSDN赞助下载:https://download.csdn.net ...
- 《图书管理系统——java》
/* (程序头部凝视開始) * 程序的版权和版本号声明部分 * Copyright (c) 2011, 烟台大学计算机学院学生 * All rights reserved. * 文件名: < ...
- java web 项目 图书管理系统的设计与实现
java web 项目 图书管理系统的设计与实现
- 基于Java SE集合的图书管理系统
图书管理系统一.需求说明1.功能:登录,注册,忘记密码,管理员管理,图书管理.2.管理员管理:管理员的增删改查.3.图书管理:图书的增删改查.4.管理员属性包括:id,姓名,性别,年龄,家庭住址,手机 ...
随机推荐
- [转帖] Linux命令拾遗-使用blktrace分析io情况
https://www.cnblogs.com/codelogs/p/16060775.html 原创:打码日记(微信公众号ID:codelogs),欢迎分享,转载请保留出处. 简介# 一般来说,想检 ...
- 【转帖】3.JVM内存结构概述
目录 1.JVM内存结构 1.JVM内存结构 在JVM系列的第一篇文章中已经给出了JVM内存结构的简图,下面是JVM内存结构更加详细的图. 同样,JVM的内存结构可以分为上中下3层. 上层主要是类加载 ...
- 最简单的以CentOS为base images 安装 Nodejs等操作的方法
镜像内安装NodeJS的简单方法 公司内有产品需要安装nodejs以便进行相关操作,Linux和Windows时没有问题,但是如果是镜像的话可能会稍微复杂一点, 这里简单进行一下总结, 以便备忘. 1 ...
- 大模型应用开发:为产品创建一个AI客服/智能助手
欢迎阅读本系列文章!我将带你一起探索如何使用OpenAI API来开发GPT应用.无论你是编程新手还是资深开发者,都能在这里获得灵感和收获. 本文将继续展示AI助手的开发方式,在OpenAPI中它的名 ...
- docker上部署启动RabbitMQ
在docker上部署启动RabbitMQ及使用 一.docker上部署启动RabbitMQ 1.查询rabbitmq镜像 docker search rabbitmq:management 2.拉取r ...
- Fabric网络升级(三)
原文来自这里. 如果不熟悉capability,那么操作前可以查阅Capabilities.需要注意的是在启用capabilities前,需要升级归属该通道的peer节点和排序节点. 更多关于最新版F ...
- HTMl插入视频背景
插入视频背景一段简单的css即可 首先定义HTML的video标签 <video src="视频路径" class="bjimg" autoplay lo ...
- 5.12 汇编语言:仿写While循环语句
循环语句(While)一种基本控制结构,它允许程序在条件为真的情况下重复执行一段代码块,直到条件为假为止.循环语句在处理需要重复执行的任务时非常有用,它可以让程序更加高效地处理大量数据或者重复性操作. ...
- SpringBoot 整合多数据源的事务问题
代码 先贴代码: 核心就是:Spring给我们提供的一个类 AbstractRoutingDataSource,然后我们再写一个切面来切换数据源,肯定要有一个地方存储key还要保证上下文都可用,所以我 ...
- 教你用JavaScript实现调皮的字母
案例介绍 欢迎来到我的小院,我是霍大侠,恭喜你今天又要进步一点点了!我们来用JavaScript编程实战案例,制作提高打字速度的小游戏-调皮的字母.点击与屏幕上字母相对应的按键,若按键与出现的字母一致 ...