项目实战 图书信息管理系统(Maven,mybatis)(第一个自己独立完成的项目)

Posted Dreamchaser追梦

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了项目实战 图书信息管理系统(Maven,mybatis)(第一个自己独立完成的项目)相关的知识,希望对你有一定的参考价值。

一、实验目的

题目七 图书信息管理系统

1 功能描述

设计一个图书信息管理系统,使之具有新建图书信息、显示、插入、删除、查询和排序等功能。

2 具体设计要求

图书信息包括:图书编号、书名、作者名、出版单位、出版时间、价格等。

系统以菜单方式工作:

① 图书信息录入(要求图书信息用文件保存)

② 图书信息浏览

③ 插入图书信息

④ 查询(可以有多种查询方式,如按书名查询、按作者名查询、按价格查询等);

⑤ 排序(可以按图书编号排序、按书名排序、按出版时间排序、按价格排序等);

⑥ 修改图书信息

⑦ 删除图书信息

二、项目概况

1.总述

此项目为图书信息管理系统,是一个采用了mysql+mybatis框架+java编写的maven项目

2. 技术栈选择

Mysql,mybatis

3.环境介绍

数据库:mysql8.0

框架:mybatis

项目结构:maven3.0

语言:Java

Jdk版本:jdk11.0.5(Jdk8.0以上)

编写的IDE:IDEA 2020.01

依赖jar包:

4. 功能概述

该图书信息管理系统实现了便捷的图书信息管理,利用命令行操作的方式让用户的操作更为简洁。

本系统提供Sql和noSql两种运行模式。

Sql模式直接对mysql数据库进行操作,便于数据的持久化和规范化,让数据能够更加便捷高效,同时可以存储大量数据,便于进行大数据的管理,如果你想真正用此系统管理你的信息,建议采用此种模式。

noSql模式是把数据载入内存中,优点是速度快,但缺点也很明显,在面对大量数据的情况下显得有些力不从心,此模式建议在数据量小的情况下使用。

两种模式都支持以下功能:

5.功能结构

6.项目文件结构

三、数据结构描述

1.实体类Book(持久化层)

2.Sql模式下的数据库结构

库名:library

表名:books

字段名代表含义数据类型格式
id图书编号INT主键,PK,not null
title书名VARCHAR(20)not null
name作者名VARCHAR(20)not null
publisher出版商VARCHAR(20)
time出版时间DATE
price价格DECIMAL(7,4)

3.Sql模式下的Mapper映射(接口结构)

4.noSql模式下的数据结构

采用LinkedList<Book>来维护图书信息

四、程序模块描述

该项目大致分为两个一级模块,分别在两个java文件中

各个文件内用分别有若干个二级模块

1.图书信息录入(通过文件录入)模块

2. 图文信息浏览模块

3. 插入模块

4. 查询模块

其下按查询条件有分为若干个三级模块

5. 排序模块

其下按排序条件有分为若干个三级模块

6. 更新模块

7. 删除模块

8. 写出模块

至于各模块的功能,见名知意,在此就不一一赘述了。

而对于各个模块的返回值和参数,容我卖个关子,此内容将在下个模块中讲解!

五、主要功能模块的算法流程图

1.Sql模式下的算法流程(以查找为例)

2. 各个模块间的连接算法流程

"套娃"式的连接方式

何为"套娃"?

可以理解为类似递归的连接方式。

与递归有什么不同?

如果采用递归,就要把低层级的模块套在高层级的模块里。这样子虽然连接了各个模块,达到了类似菜单的效果,但有以下两个较为致命的缺点:

  1. 当运行完一个模块后,该模块就运行结束,无法做到循环操作,这与实验要求不符

  2. 由于该项目是一个系统,各模块间要不断退出重进,循环多次的递归会造成堆栈不断压缩,有堆栈溢出风险

    那我们该如何做呢?

    对于第一个缺点,我采用了一个死循环来解决;对于第二个缺点,我的思路就是把改变模块重复调用的时机和位置,让它既能达到效果,又不会导致堆栈溢出

    基本思路:

    每个函数都有一个整数类型的返回值,只要返回1,就说明该级模块需要退回上一级;返回0则说明不需要,即留在当前模块。

    而是留在当前模块还是返回上一级模块,由该模块(记为模块3)的上一级(记为模块2)控制,如果模块3返回一了,就在模块2的上一级(记为模块1)再次调用模块2,即可做到返回上一层;而如果模块3返回0则在模块2再次循环调用,直至模块返回1
    这样做不仅能实现功能,而且能避免多次"套娃"导致堆栈溢出的风险

六、代码清单

1.项目结构全览

2. 实体类Book

ackage com.dreamchaser.domain;

import java.math.BigDecimal;
import java.util.Date;

/**
 * books
 * 
 * @author 金昊霖
 */
public class Book 

    /** 图书编号 */
    private Integer id;

    /** 图书名称 */
    private String title;

    /** 作者姓名 */
    private String name;

    /** 出版社 */
    private String publisher;

    /** 出版时间 */
    private Date time;

    /** 价格 */
    private BigDecimal price;

    public Book() 
    

    /**
     * 用于清空对象里的数据
     */
    public void clear()
        this.id=null;
        this.title=null;
        this.name=null;
        this.publisher=null;
        this.time=null;
        this.price=null;
    

    public Book(Integer id, String title, String name, String publisher, Date time, BigDecimal price) 
        this.id = id;
        this.title = title;
        this.name = name;
        this.publisher = publisher;
        this.time = time;
        this.price = price;
    

    public Book(BigDecimal price) 
        this.price = price;
    

    /**
     * 获取图书编号
     * 
     * @return 图书编号
     */
    public Integer getId() 
        return this.id;
    

    /**
     * 设置图书编号
     * 
     * @param id
     *          图书编号
     */
    public void setId(Integer id) 
        this.id = id;
    

    /**
     * 获取图书名称
     * 
     * @return 图书名称
     */
    public String getTitle() 
        return this.title;
    

    /**
     * 设置图书名称
     * 
     * @param title
     *          图书名称
     */
    public void setTitle(String title) 
        this.title = title;
    

    /**
     * 获取作者姓名
     * 
     * @return 作者姓名
     */
    public String getName() 
        return this.name;
    

    /**
     * 设置作者姓名
     * 
     * @param name
     *          作者姓名
     */
    public void setName(String name) 
        this.name = name;
    

    /**
     * 获取出版社
     * 
     * @return 出版社
     */
    public String getPublisher() 
        return this.publisher;
    

    /**
     * 设置出版社
     * 
     * @param publisher
     *          出版社
     */
    public void setPublisher(String publisher) 
        this.publisher = publisher;
    

    /**
     * 获取出版时间
     * 
     * @return 出版时间
     */
    public Date getTime() 
        return this.time;
    

    /**
     * 设置出版时间
     * 
     * @param time
     *          出版时间
     */
    public void setTime(Date time) 
        this.time = time;
    

    /**
     * 获取价格
     * 
     * @return 价格
     */
    public BigDecimal getPrice() 
        return this.price;
    

    /**
     * 设置价格
     * 
     * @param price
     *          价格
     */
    public void setPrice(BigDecimal price) 
        this.price = price;
    

  

3.Mapper映射

①接口类 BooKMapper

package com.dreamchaser.mapper;

import com.dreamchaser.domain.Book;

import java.util.List;
import java.util.Map;

public interface BookMapper 
    public List<Book> selectSmaller(Map<String,Object> map);
    public List<Book> selectAll();
    public List<Book> selectBigger(Map<String,Object> map);
    public List<Book> findBookByCondition(Map<String,Object> map);
    public List<Book> findBooksById(int id);
    public void insertBook(Map<String,Object> map);
    public void insertBooks(List<Book> books);
    public void updateBookById(Map<String,Object> map);
    public void updateBooks(List<Map<String,Object>> list);
    public void deleteBookById(int id);
    public void deleteBooksByIds(List<Integer> ids);
    /**
     * @param map 要注意这里的map中只能有一个对象
     * @return
     */
    public List<Book> findBookByConditionO(Map<String,Object> map);

②BookMapper.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">

<!-- books 路径不是/,而是.!!!-->
<mapper namespace="com.dreamchaser.mapper.BookMapper">
    <!-- 字段映射 -->
    <resultMap id="booksMap" type="Book">
        <!--设置主键,提高mybatis性能-->
        <id property="id" column="id"/>
    </resultMap>



    <!-- 表查询字段 -->
    <sql id="allColumns">
        b.id, b.title, b.name, b.publisher, b.time, b.price
    </sql>

    <!-- 查询小于条件的结果 多条会自动打包成list  注:&lt;指的是<,在xml中<是非法的 -->
    <select id="selectSmaller" parameterType="map" resultMap="booksMap">
        SELECT
        <include refid="allColumns"/>
        from books b
        <where>
            <if test="time != null and time!=''">
                AND b.time &lt;=#time
            </if>
            <if test="price != null and price !=''">
                AND b.price &lt;=#price
            </if>
        </where>
    </select>

    <!-- 查询小于条件的结果   注:&lt;指的是<,在xml中<是非法的 -->
    <select id="selectBigger" parameterType="map" resultMap="booksMap">
        SELECT
        <include refid="allColumns"/>
        from books b
        <where>
            <if test="time != null and time!=''">
                AND b.time >=#time
            </if>
            <if test="price != null and price !=''">
                AND b.price >=#price
            </if>
        </where>
    </select>
    <!-- 查询所有数据 -->
    <select id="selectAll" resultMap="booksMap">
        SELECT
        <include refid="allColumns" />
        FROM books b
    </select>
    
    <!-- 根据条件参数查询数据列表 -->
    <select id="findBookByCondition" resultMap="booksMap" parameterType="map">
        SELECT
        <include refid="allColumns" />
        FROM books b WHERE 1 = 1
        <if test="title != null and title != ''">
            AND b.title LIKE CONCAT('%', #title, '%')
        </if>
        <if test="name != null and name != ''">
            AND b.name LIKE CONCAT('%', #name, '%')
        </if>
        <if test="publisher != null and publisher != ''">
            AND b.publisher LIKE CONCAT('%', #publisher, '%')
        </if>
        <if test="time != null">
            AND b.time = #time
        </if>
        <if test="price != null">
            AND b.price = #price
        </if>
    </select>
    
    <!-- 根据主键查询数据 -->
    <select id="findBooksById" resultMap="booksMap" parameterType="int">
        SELECT
        <include refid="allColumns" />
        FROM books b WHERE b.id =#id
    </select>
    
    <!-- 插入数据 -->
    <insert id="insertBook" parameterType="map">
        INSERT INTO books (
            id, title, name, publisher, time, price
        ) VALUES (
            #id,
            #title,
            #name,
            #publisher,
            #time,
            #price
        )
    </insert>
    
    <!-- 批量插入数据 -->
    <insert id="insertBooks" parameterType="list">
        INSERT INTO books (
            id, title, name, publisher, time, price
        ) VALUES
        <foreach collection="list" index="index" item="item" separator=",">
            (
                #item.id,
                #item.title,
                #item.name,
                #item.publisher,
                #item.time,
                #item.price
            )
        </foreach>
    </insert>
    
    <!-- 修改数据 -->
    <update id="updateBookById" parameterType="map">
        UPDATE books
        <set>
            <if test="title != null">
                title = #title,
            </if>
            <if test="name != null">
                name = #name,
            </if>
            <if test="publisher != null">
                publisher = #publisher,
            </if>
            <if test="time != null">
                time = #time,
            </if>
            <if test="price != null">
                price = #price
            </if>
        </set>
        WHERE id = #id
    </update>
    
    <!-- 批量修改数据 -->
    <update id="updateBooks" parameterType="list">
        <foreach collection="list" index="index" item="item" separator=";">
            UPDATE books
            <set>
                <if test="item.title != null">
                    title = #item.title,
                </if>
                <if test="item.name != null">
                    name = #item.name,
                </if>
                <if test="item.publisher != null">
                    publisher = #item.publisher,
                </if>
                <if test="item.time != null">
                    time = #item.time,
                </if>
                <if test="item.price != null">
                    price = #item.price
                </if>
            </set>
            WHERE id = #item.id
        </foreach>
    </update>
    
    <!-- 根据主键删除数据 -->
    <delete id="deleteBookById" parameterType="int">
        DELETE FROM books WHERE id = #id
    </delete>
    
    <!-- 根据主键批量删除数据 -->
    <delete id="deleteBooksByIds" parameterType="list">
        DELETE FROM books WHERE id IN
        <foreach collection="list" index="index" item="id" open="(" separator="," close=")">
            #id
        </foreach>
    </delete>

    <!-- 根据条件排序查询-->
    <select id="findBookByConditionO" resultMap="booksMap" parameterType="map">
        SELECT
        <include refid="allColumns" />
        FROM books b WHERE 1 = 1
        <if test="title != null and title != ''">
            ORDER BY title
        </if>
        <if test="name != null and name != ''">
            ORDER BY name
        </if>
        <if test="time != null">
            ORDER BY time
        </if>
        <if test=<

以上是关于项目实战 图书信息管理系统(Maven,mybatis)(第一个自己独立完成的项目)的主要内容,如果未能解决你的问题,请参考以下文章

Java项目:图书管理系统(java+SSM+jsp+mysql+maven)

Java全栈web网页技术:16.书城项目实战五:图书的分页显示

Java全栈web网页技术:16.书城项目实战五:图书的分页显示

Java全栈web网页技术:16.书城项目实战五:图书的分页显示

Maven实战读书笔记:Maven概述

实战小项目之借书系统