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,姓名,性别,年龄,家庭住址,手机 ...
随机推荐
- [转帖]一口气看完45个寄存器,CPU核心技术大揭秘
https://www.cnblogs.com/xuanyuan/p/13850548.html 序言 前段时间,我连续写了十来篇CPU底层系列技术故事文章,有不少读者私信我让我写一下CPU的寄存器. ...
- SPECJVM2008 再学习
SPECJVM2008 再学习 摘要 昨天的太水了 感觉今天有必要再水一点.. 存在的问题 默认进行启动 sunflow 必定过不去. 一般的解决办法要求进行重新编译 但是我不知道怎么下载源码... ...
- [转帖]Linux小知识:sudo su和su的区别
https://www.cnblogs.com/jiading/p/11717388.html su是申请切换root用户,需要申请root用户密码.有些Linux发行版,例如ubuntu,默认没有设 ...
- Chrome 下载地址
今天同事找到一个网页 感觉非常好用 这里保存并且推荐一下 https://www.chromedownloads.net/chrome64win-stable/
- vue全局事件总线和消息订阅详细讲解
全局事件总线 在写组件的时候,我们都知道父传递子 也知道子传递给父 但是组件间嵌套复杂的时候我们应该怎么通信呢? 有的小伙伴会说适用vuex,的确是可以解决问题的 下面我们说一下全局事件总线 一种组件 ...
- vue结合elementUI折叠展开效果动画
组件 <template> <div class="hide-page-com"> <ul class="tab-tilte"&g ...
- 数组 vs. 切片
在Go编程语言中处理数据时,经常会遇到数组和切片.这两者是不同的数据结构,有各自的特性和用途.本文将对Go中的数组和切片进行比较,以帮助大家更好地理解它们. 1. 长度不同 一个主要的区别是长度.在G ...
- 用Unity3D做游戏开发在Android上的常用调试方法
Hdg Remote Debug 远程调试 游戏运行在手机上,可以通过pc端的unity来随时修改当前场景中GameObject的变量,从而改变手机上运行时的表现.比如,我可以勾掉下图中的" ...
- Docker 安装 Nacos 注册中心
废话不多说直接上安装脚本: 在运行安装脚本之前,首先,我们查看一下 Nacos 的版本分别有哪些使用 docker search nacos: 然后在执行: docker pull nacos/nac ...
- BoostAsyncSocket 异步反弹通信案例
Boost 利用ASIO框架实现一个跨平台的反向远控程序,该远控支持保存套接字,当有套接字连入时,自动存储到map容器,当客户下线时自动从map容器中移除,当我们需要与特定客户端通信时,只需要指定客户 ...