导航:

pre:  6.图书管理

next:8.续借图书

只挑重点的讲,具体的请看项目源码。

1.项目源码

需要源码的朋友,请捐赠任意金额后留下邮箱发送:)

2.页面设计

2.1 bookBorrow.html

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml" xmlns:th="http://www.thymeleaf.org"> <head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
<title>借阅图书</title>
<link rel="stylesheet" href="/static/layui/css/layui.css" th:href="@{/static/layui/css/layui.css}"> </head> <body>
<!-- 内容主体区域 -->
<div>
<!--<div class="demoTable" style="padding: 15px">
搜索:
<div class="layui-inline">
<input class="layui-input" id="find" autocomplete="off">
</div>
<button class="layui-btn" data-type="reload" id="queryRole">搜索</button>
</div>-->
<div>
<div class="search-div">
<div class="">
<div class="layui-inline">
<label class="layui-form-label">读者编码:</label>
<div class="layui-input-inline">
<input class="layui-input" id="readerCode" name="readerCode" autocomplete="off">
</div>
</div>
<div class="layui-inline">
<label class="layui-form-label">ISBN:</label>
<div class="layui-input-inline">
<input class="layui-input" id="isbn" name="isbn" autocomplete="off">
</div>
</div> <button class="layui-btn" data-type="reload" id="search">搜索</button>
</div> </div> <table id="tb-book" lay-filter="tb-book"></table> </div>
<table id="tb_bookBorrow" lay-filter="tb_bookBorrow"></table> </div> <!--编辑表单-->
<script type="text/html" id="book-toolbar">
<div class="layui-btn-container">
<button class="layui-btn layui-btn-sm" lay-event="add"><i class="layui-icon"></i>新增</button>
<button class="layui-btn layui-btn-sm layui-btn-danger" lay-event="remove"><i class="layui-icon"></i>删除
</button>
<button class="layui-btn layui-btn-sm" lay-event="refresh"><i class="layui-icon"></i>刷新
</button>
</div>
<!--<div class="layui-btn-container">
<button class="layui-btn layui-btn-sm" lay-event="getCheckData">获取选中行数据</button>
<button class="layui-btn layui-btn-sm" lay-event="getCheckLength">获取选中数目</button>
<button class="layui-btn layui-btn-sm" lay-event="isAll">验证是否全选</button>
</div>-->
</script> <script type="text/html" id="barOps">
<a class="layui-btn layui-btn-sm" lay-event="edit"><i class="layui-icon"></i> </a>
</script> <script src="/static/js/jquery-1.11.3.min.js" th:src="@{/static/js/jquery-1.11.3.min.js}"></script>
<script src="/static/layui/layui.all.js" th:src="@{static/layui/layui.all.js}"></script>
<script src="/static/js/util.js" th:src="@{/static/js/util.js}"></script> <!--ctx-->
<script th:replace="~{fragment::ctx}"/> <script>
var element, layer, laydate, table, form,userTable; function reload(){
userTable.reload();
} $(function () {
// 使用模块
layui.use(['element', 'layer', 'laydate', 'table', 'form'], function () {
element = layui.element;
layer = layui.layer;
laydate = layui.laydate;
table = layui.table;
form = layui.form;
}); element.on('tab(demo)', function(data){
var src=$(".layui-tab-item.layui-show").find("iframe").attr("src");
$(".layui-tab-item.layui-show").find("iframe").attr("src",src);
}); //第一个实例
userTable = table.render({
elem: '#tb_bookBorrow'
, height: 515
, url: ctx+'api/bookBorrow/getPageResult' //数据接口
, page: true //开启分页
, toolbar: '#book-toolbar'
/*,request: {
pageName: 'pageNo' //页码的参数名称,默认:page
,limitName: 'pageSize' //每页数据量的参数名,默认:limit
}
, response: {
statusName: 'code', //规定返回的状态码字段为code
statusCode: 200 //规定成功的状态码为200,默认为0
}
, parseData: function (res) {
return {
"code": res.code, //解析接口状态
"msg": res.msg, //解析提示文本
"count": res.records, //解析数据长度
"data": res.rows //解析数据列表
}
}*/
, cols: [
[ //表头
{type: 'checkbox', fixed: 'left'}
, {field: 'id', title: 'ID', width: 80, sort: true, fixed: 'left',hide:true}
, {field: 'borrowStatus', title: '状态', width: 80,templet:showStatus}
, {field: 'readerCode', title: '读者编码', width: 160}
, {field: 'readerName', title: '读者姓名', width: 160}
, {field: 'readerSex', title: '读者性别', width: 120}
, {field: 'readerPhone', title: '读者电话', width: 160}
, {field: 'bookIsbn', title: '图书ISBN', width: 160}
, {field: 'bookName', title: '图书名称', width: 160}
, {field: 'bookAuthor', title: '图书作者', width: 120}
, {field: 'bookCategory', title: '图书分类', width: 120}
, {field: 'bookLocation', title: '图书位置', width: 180}
, {field: 'bookTotal', title: '图书数量', width: 120}
, {field: 'bookLeft', title: '图书剩余', width: 120}
, {field: 'borrowDate', title: '借阅日期', width: 120,templet:'<div>{{ layui.util.toDateString(d.borrowDate, "yyyy-MM-dd") }}</div>'}
, {field: 'returnDate', title: '应还日期', width: 120,templet:'<div>{{ layui.util.toDateString(d.returnDate, "yyyy-MM-dd") }}</div>'}
, {field: 'borrowDays', title: '借阅天数', width: 120}
, {field: 'remark', title: '备注', width: 180}
, {fixed: 'right', title: '操作', toolbar: '#barOps', width: 120}
]
]
}); //工具栏事件
table.on('toolbar(tb_bookBorrow)', function (obj) {
var checkStatus = table.checkStatus(obj.config.id);
var checkData = checkStatus.data;
var ids = [];
switch (obj.event) {
// 新增
case 'add':
cleanForm("#saveBook"); top.layer.open({
type: 2,
offset: '10px',
title: "新增借阅",
area: ['800px', '680px'],
content: ['bookBorrowAdd']
});
break;
// 删除
case 'remove':
if (checkData.length == 0) {
layer.alert('请选择要操作的行');
} else {
layer.confirm('确定要删除吗?', function (index) {
for (var i = 0; i < checkData.length; i++) {
ids.push(checkData[i].id);
}
//layer.alert(JSON.stringify(ids));
$.ajax({
url: ctx+'api/bookBorrow/remove',
type: 'POST',
contentType: "application/json",
dataType: "json",
data: JSON.stringify(ids),
success: function (result) {
if (result.code == 200) {
setTimeout(function () {
layer.closeAll();//关闭所有的弹出层
userTable.reload();
}, 300);
}else {
layer.msg("操作失败!", {icon: 5});
}
}
});
});
}
break;
case 'refresh':
userTable.reload();
break;
case 'getCheckData':
layer.alert(JSON.stringify(data));
break;
case 'getCheckLength':
var data = checkStatus.data;
layer.msg('选中了:' + data.length + ' 个');
break;
case 'isAll':
layer.msg(checkStatus.isAll ? '全选' : '未全选')
break;
}
;
}); // 监听工具条
table.on('tool(tb_bookBorrow)', function (obj) {
var data = obj.data;
// 修改
if (obj.event === 'edit') {
top.layer.open({
type: 2,
offset: '10px',
title: "修改借阅",
area: ['800px', '680px'],
content: [ctx+'bookBorrowEdit/'+data.id]
});
}
}); // 搜索
$('#search').click(function () {
var readerCode = $('#readerCode').val();
var isbn = $('#isbn').val();
table.reload('tb_bookBorrow', {
url: ctx+'api/bookBorrow/getPageResult'
,where: {
readerCode:readerCode,isbn:isbn
}
,page: {
curr: 1
}
});
});
}); // 借阅状态
function showStatus(data) {
var status = data.borrowStatus;
var result;
if (status == 0) {
result = '<a class="" style="color:#FF5722">未还</a>';
}
if (status == 1) {
result = '<a class="" style="color:#009688">已还</a>';
}
if (status == 2) {
result = '<a class="" style="color:#FF5722">逾期</a>';
}
return result;
} </script>
</body> </html>

3.借阅管理service

/**
* @Description: 借阅图书服务
* @Author laoxu
* @Date 2020/1/12
**/
@Service
public class BookBorrowService extends AbstractService {
public void add(BookBorrowVO entity) {
//String username = SecurityUtil.getLoginUser();
insert("bookBorrowMapper.insert",entity);
} public void modify(BookBorrowVO entity) {
update("bookBorrowMapper.update",entity);
} public void remove(Long id) {
delete("bookBorrowMapper.delete",id);
} public void removes(Long[] ids) {
delete("bookBorrowMapper.deletes",ids);
} public void returnBook(Map<String, Object> param) {
delete("bookBorrowMapper.return",param);
} public BookBorrowVO get(Long id) {
return selectOne("bookBorrowMapper.select",id);
} public List<BookBorrow> getParentList(Long id) {
return selectList("bookBorrowMapper.selectParentList",id);
} public int count(Map<String, Object> param) {
return selectOne("bookBorrowMapper.count",param);
} public List<BookBorrow> getList(Map<String, Object> param) {
return selectList("bookBorrowMapper.selectList",param);
} public List<BookBorrowVO> getPageResult(Map<String, Object> param) {
return selectList("bookBorrowMapper.selectPageResult",param);
} public int checkBorrow(BookBorrowVO entity){
return selectOne("bookBorrowMapper.countBorrow",entity);
} public int getBorrowCount(String date){
return selectOne("bookBorrowMapper.selectBorrowCount",date);
} public int getReturnCount(String date){
return selectOne("bookBorrowMapper.selectReturnCount",date);
}
}

4.借阅管理controller

/**
* @Description: 借阅图书控制器
* @Author laoxu
* @Date 2020/1/12 23:24
**/
@RestController
@RequestMapping("/api/bookBorrow")
public class BookBorrowController {
@Autowired
BookBorrowService bookBorrowService; @Autowired
BookReaderService bookReaderService; @Autowired
BookService bookService; /**
* 保存(新增/修改)
*
* @param entity
* @return
*/
@PostMapping("/save")
public Result<String> modify(@RequestBody BookBorrowVO entity) {
Long id = entity.getId();
if(id!=null){
bookBorrowService.modify(entity);
}else{
Map<String,Object> param = new HashMap<>();
param.put("isbn",entity.getBookIsbn());
param.put("code",entity.getReaderCode());
//1.检查读者编号是否存在
if(bookReaderService.count(param)==0){
return ResultUtil.fail("读者不存在!");
}
//2.检查图书编号是否存在
if(bookService.count(param)==0){
return ResultUtil.fail("图书不存在!");
}
//3.检查该读者是否已经借过此书
int count = bookBorrowService.checkBorrow(entity);
if(count>0){
return ResultUtil.fail("您已借过该图书!");
}
//4.检查图书剩余
Book book = bookService.getByIsbn(entity.getBookIsbn());
int leftNumber = book.getLeftNumber();
if(leftNumber<1){
return ResultUtil.fail("图书剩余数量为0!");
}
//5.扣减图书剩余
book.setLeftNumber(leftNumber-1);
bookService.modify(book);
//6.保存借阅记录
bookBorrowService.add(entity);
} return ResultUtil.ok();
} @PostMapping("/remove")
public Result<String> remove(@RequestBody Long[] ids) {
bookBorrowService.removes(ids);
return ResultUtil.ok();
} /**
* 归还
* @param ids
* @return
*/
@PostMapping("/return")
@Transactional
public Result<String> returnBook(@RequestBody Long[] ids) {
// 1.增加图书库存
Book entity = null;
for (Long id: ids) {
entity = bookService.getByIsbn(bookBorrowService.get(id).getBookIsbn());
entity.setLeftNumber(entity.getLeftNumber()+1);
bookService.modify(entity);
}
// 2.更新借阅状态
Map<String,Object> param = new HashMap<>();
param.put("ids", ids);
param.put("borrowStatus",1);
bookBorrowService.returnBook(param); return ResultUtil.ok();
} @GetMapping("/get")
public Result<BookBorrowVO> get(@RequestParam("id") Long id) {
BookBorrowVO entity = bookBorrowService.get(id); return ResultUtil.ok(entity);
} @GetMapping("/getPageResult")
public ResultBean<List<BookBorrowVO>> getPageResult(
@RequestParam(required = false) Integer[] borrowStatus,
@RequestParam(required = false) String readerCode,
@RequestParam(required = false) String isbn,
@RequestParam(defaultValue = "1") Integer page,
@RequestParam(defaultValue = "10") Integer limit) { Map<String, Object> param = new HashMap<>();
// 统计记录数
int totalRows = bookBorrowService.count(param);
// 计算起始行号
int offset = (page - 1) * limit;
int rows = limit; param.put("offset", offset);
param.put("rows", rows);
param.put("borrowStatus",borrowStatus);
param.put("readerCode",readerCode);
param.put("isbn",isbn); // 获取当前页结果集
List<BookBorrowVO> entities = bookBorrowService.getPageResult(param); ResultBean result = new ResultBean(0, "查询成功", totalRows, entities); return result; } @GetMapping("/getBorrowStat")
public Result<Map<String,Object>> getBorrowStat(){
Map<String,Object> map = new HashMap<>();
List<String> days = DateUtil.getDaysBetwwen(6); map.put("columnName",days);
BorrowStatVO borrowVO = new BorrowStatVO();
BorrowStatVO returnVO = new BorrowStatVO();
borrowVO.setName("借");
returnVO.setName("还");
borrowVO.setType("bar");
returnVO.setType("bar");
List<Integer> borrowData = new ArrayList<>();
List<Integer> returnData = new ArrayList<>();
for (String day:days) {
borrowData.add(bookBorrowService.getBorrowCount(day));
returnData.add(bookBorrowService.getReturnCount(day));
}
borrowVO.setData(borrowData);
returnVO.setData(returnData); List<BorrowStatVO> list = new ArrayList<>();
list.add(borrowVO);
list.add(returnVO); map.put("columnValue",list); return ResultUtil.ok(map); }
}

Spring Boot图书管理系统项目实战-7.借阅图书的更多相关文章

  1. Spring Boot → 11:项目实战-账单管理系统完整版

    Spring Boot → 11:项目实战-账单管理系统完整版

  2. Spring Boot → 06:项目实战-账单管理系统

    Spring Boot → 06:项目实战-账单管理系统

  3. Java 架构师+高并发+性能优化+Spring boot大型分布式项目实战

    视频课程内容包含: 高级 Java 架构师包含:Spring boot.Spring cloud.Dubbo.Redis.ActiveMQ.Nginx.Mycat.Spring.MongoDB.Zer ...

  4. 新书上线:《Spring Boot+Spring Cloud+Vue+Element项目实战:手把手教你开发权限管理系统》,欢迎大家买回去垫椅子垫桌脚

    新书上线 大家好,笔者的新书<Spring Boot+Spring Cloud+Vue+Element项目实战:手把手教你开发权限管理系统>已上线,此书内容充实.材质优良,乃家中必备垫桌脚 ...

  5. 图书-技术-SpringBoot:《Spring Boot 企业级应用开发实战》

    ylbtech-图书-技术-SpringBoot:<Spring Boot 企业级应用开发实战> Spring Boot 企业级应用开发实战,全书围绕如何整合以 Spring Boot 为 ...

  6. 从零一起学Spring Boot之LayIM项目长成记(五)websocket

    前言 距离上一篇已经比较久的时间了,项目也是开了个头.并且,由于网上的关于Spring Boot的websocket讲解也比较多.于是我采用了另外的一个通讯框架 t-io 来实现LayIM中的通讯功能 ...

  7. Spring Boot会员管理系统——处理文件上传

    温馨提示 Spring Boot会员管理系统的中,需要涉及到Spring框架,SpringMVC框架,Hibernate框架,thymeleaf模板引擎.所以,可以学习下这些知识.当然,直接入门的话使 ...

  8. 使用Spring Boot开发Web项目(二)之添加HTTPS支持

    上篇博客使用Spring Boot开发Web项目我们简单介绍了使用如何使用Spring Boot创建一个使用了Thymeleaf模板引擎的Web项目,当然这还远远不够.今天我们再来看看如何给我们的We ...

  9. 从零一起学Spring Boot之LayIM项目长成记(二) LayIM初体验

    前言 接上篇,已经完成了一个SpringBoot项目的基本搭建.那么现在就要考虑要做什么,怎么做的问题.所以本篇内容不多,带大家一起来简单了解一下要做的东西,之前有很多人不知道从哪里下手,那么今天我带 ...

  10. Spring Boot 从入门到实战汇总

    之前写过几篇spring boot入门到实战的博文,因为某些原因没能继续. 框架更新迭代很快,之前还是基于1.x,现在2.x都出来很久了.还是希望能从基于该框架项目开发的整体有一个比较系统的梳理,于是 ...

随机推荐

  1. [粘贴]TiDB Lightning 断点续传

    https://www.bookstack.cn/read/tidb-6.1-zh/tidb-lightning-tidb-lightning-checkpoints.md 大量的数据导入一般耗时数小 ...

  2. 遇到疯狂GC时进行判断然后重启服务的方法-GPT学习使用之三

    遇到疯狂GC时进行判断然后重启服务的方法-GPT学习使用之三 背景 最近怀疑产品遇到了第三方组建的bug Groupdocs转换渲染某些文件时出现了严重的FullGC的情况 而且出现的奇怪的功效学GC ...

  3. [转帖]Linux实用技巧——find查找指定时间内修改过的文件或目录

    https://cloud.tencent.com/developer/article/1694949 解决方案 例:查找出五分钟内修改过的文件 [root@mobius ~]$ find ./* - ...

  4. [转帖]耗时几个月,终于找到了JVM停顿十几秒的原因

    https://www.cnblogs.com/codelogs/p/16060792.html   原创:打码日记(微信公众号ID:codelogs),欢迎分享,转载请保留出处. 简介# 最近我们系 ...

  5. 京东云RASP云原生安全免疫创新实践

    作者:京东云 刘一鑫 1 背景 随着网络攻击事件整体呈上升趋势,应用作为网络入口承载着大量业务和流量,因此成为了安全的重灾区.黑客往往借助自动化的工具以及安全漏洞,对Web进行漏洞扫描和探测,进而利用 ...

  6. 【DS】【AtCoder】Pakencamp 2022 Day2 H

    2023.6.30 Problem Link 有 \(n\) 个帮派在打架,每个帮派有一个大小 \(a_i\),每相邻两个帮派有一个仇恨度 \(b_i\).现在有 \(Q\) 次单点修改 \(a_i\ ...

  7. 无法下载安装文件,请检查internet连接

    win10 vs2019下提示visual studio installer无法下载安装文件,请检查internet连接     1.打开"网络和Internet设置",更改适配器 ...

  8. Fabric网络升级(三)

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

  9. vim 从嫌弃到依赖(18)——查找模式进阶

    上一篇文章中,我们初步结识了如何使用查找模式,也能够通过n和 N进行查找.这篇将会介绍搜索中更高级的用法.另外在写上一篇文章的时候我发现介绍查找相关内容的时候不能用动图来演示,主要是因为输入的内容太多 ...

  10. Postfix + Extmail 企业邮件服务器搭建

    ExtMail套件用于提供从浏览器中登录.使用邮件系统的Web操作界面,而Extman套件用于提供从浏览器中管理邮件系统的Web操作界面.它以GPL版权释出,设计初衷是希望设计一个适应当前高速发展的I ...