DAY17 springMVC图书管理系统源码

package com.rzgsl.controller;

import com.rzgsl.pojo.Books;
import com.rzgsl.service.BookService;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;

import java.util.ArrayList;
import java.util.List;
//这里可以用注解,也可以xml配bean,配bean必须有set方法
//@Controller
@RequestMapping("/book")
public class BookController {

// @Autowired
// @Qualifier(“BookServiceImpl”)//一个接口有多个实现类,用@合格者 注解指定装载的Bean
private BookService bookService;
public void setBookService(BookService bookService) {
this.bookService = bookService;
}

//查询全部的书,返回到展示页面
@RequestMapping("/allBook")
public String list(Model model){
    List<Books> list = bookService.queryAllBook();
    model.addAttribute("list",list);
    return "allBook";
}
//跳转到增加书籍
@RequestMapping("/toAddBook")
public String toAddPaper(){
    return "addBook";
}
//添加书籍的请求
@RequestMapping("/addBook")
public String addBook(Books books){
    System.out.println("addBook"+books);
    bookService.addBook(books);
    return "redirect:/book/allBook";
}
//跳转到修改页面
@RequestMapping("/toUpdate")
public String toUpdatePaper(int id,Model model){
    Books books = bookService.queryBookById(id);
    model.addAttribute("Qbooks",books);
    return "updateBook";
}
//修改书籍的请求
@RequestMapping("/updateBook")
public String updatePaper(Books books){
    System.out.println("updateBook"+books);
    int i = bookService.updateBook(books);
    return "redirect:/book/allBook";
}
//删除书籍
//    Restful风格
@RequestMapping("toDelete/{bookN}")
public String toDelete(@PathVariable("bookN") int id){
    int i = bookService.deleteBookById(id);
    return "redirect:/book/allBook";
}
//按书名查询书籍
//list传参,前端forEach
@RequestMapping("/queryBook")
public String queryBook(String queryBookName,Model model){
    Books books = bookService.queryBookByName(queryBookName);
    //左边要用List,不能用ArrayList,否则if语句中的list会报错
    List<Books> list = new ArrayList<>();
    list.add(books);
    if(books==null){
        list = bookService.queryAllBook();

// 用erro,前端用erro接收,不成功,必须得用error
model.addAttribute(“error”,“Null”);
}
model.addAttribute(“list”,list);
return “allBook”;

}

}

package com.rzgsl.dao;

import com.rzgsl.pojo.Books;
import org.apache.ibatis.annotations.Param;

import java.util.List;

public interface BookMapper {
//Mapper接口负责参数绑定
// 增加一本书
int addBook(Books books);
// 删除一本书
int deleteBookById(@Param(“bookID”)int id);
// 修改一本书
int updateBook(Books books);
// 查询一本书
Books queryBookById(@Param(“bookID”) int id);
// 查询所有的书
List queryAllBook();
//通过书名查询
Books queryBookByName(@Param(“BookName”) String queryBookName);
}

<?xml version="1.0" encoding="UTF-8" ?>
<!--增加一个Book-->
<insert id="addBook" parameterType="com.rzgsl.pojo.Books">
  insert into ssmbuild.books(bookName,bookCounts,detail)
  values (#{bookName}, #{bookCounts}, #{detail})
<!--根据id删除一个Book-->
<delete id="deleteBookById" parameterType="int">
  delete from ssmbuild.books where bookID=#{bookID}
<!--更新Book-->
<update id="updateBook" parameterType="com.rzgsl.pojo.Books">
  update ssmbuild.books
  set bookName = #{bookName},bookCounts = #{bookCounts},detail = #{detail}
  where bookID = #{bookID}
<!--根据id查询,返回一个Book-->
<select id="queryBookById" resultType="com.rzgsl.pojo.Books">
  select * from ssmbuild.books
  where bookID = #{bookID}
<!--查询全部Book-->
<select id="queryAllBook" resultType="com.rzgsl.pojo.Books">
  SELECT * from ssmbuild.books
<select id="queryBookByName" resultType="Books">
    select * from ssmbuild.books
  where bookName = #{BookName}
</select>

package com.rzgsl.pojo;

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

@Data
@AllArgsConstructor
@NoArgsConstructor
public class Books {
private int bookID;
private String bookName;
private int bookCounts;
private String detail;
}

package com.rzgsl.service;

import com.rzgsl.pojo.Books;
import org.springframework.stereotype.Service;

import java.util.List;

public interface BookService {
// 增加一本书
int addBook(Books books);
// 删除一本书
int deleteBookById(int id);
// 修改一本书
int updateBook(Books books);
// 查询一本书
Books queryBookById(int id);
// 查询所有的书
List queryAllBook();
// 通过书名查询
Books queryBookByName (String queryBookName);
}

package com.rzgsl.service;

import com.rzgsl.dao.BookMapper;
import com.rzgsl.pojo.Books;

import java.util.List;

public class BookServiceImpl implements BookService {

//service调dao层
private BookMapper bookMapper;
public void setBookMapper(BookMapper bookMapper){
    this.bookMapper = bookMapper;
}
@Override
public int addBook(Books books) {
    return bookMapper.addBook(books);
}

@Override
public int deleteBookById(int id) {
    return bookMapper.deleteBookById(id);
}

@Override
public int updateBook(Books books) {
    return bookMapper.updateBook(books);
}

@Override
public Books queryBookById(int id) {
    return bookMapper.queryBookById(id);
}

@Override
public List<Books> queryAllBook()
一、项目简介 本项目是一套基于SpringBoot的图书管理系统,主要针对计算机相关专业的正在做毕设的学生和需要项目实战练习的Java学习者。 包含:项目源码、数据库脚本、软件工具、项目说明等,该项目可以直接作为毕设使用。 项目都经过严格调试,确保可以运行! 二、技术实现 ​后台框架:SpringBoot ​数据库:MySQL 开发环境:JDK、IDEA、Tomcat 三、系统功能 本图书管理系统主要包含两种角色:读者和管理员。读者只能对个人信息的查阅、修改,图书的查询,而管理员则可以进行图书信息及借阅信息的管理。 具体实现功能如下: (1)系统登录。分为普通读者登录和管理员登录。 (2)系统管理。系统管理包括管理员设置,以及图书类别设置。管理员设置包括管理员信息的设置以及密码的设置。图书类别的设置只有管理员才可以对他进行新增,修改和删除。 (3)图书管理。包括图书信息管理,图书信息查询。只有管理员才可以对图书进行管理,图书查询是帮助读者方便查找图书信息。 (4)读者管理。读者管理包括读者信息管理,以及读者信息的查询。读者信息查询可以根据读者的姓名和编号进行查询。读者信息管理只对管理员有用,只有管理员可以添加读者,修改和删除读者的信息。 (5)图书借阅管理。图书借阅包括图书的借阅,归还以及续借。图书的借阅以及归还只对管理员起作用,只有通过管理员才可以进行图书的借阅以及归还。读者只能对图书进行续借的操作。 该系统功能完善、界面美观、操作简单、功能齐全、管理便捷,具有很高的实际应用价值。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值