JAVA之图书借阅管理

目录

图书借阅管理项目简介

项目框架

图书表信息

代码展示

主界面

查询图书种类

 查询图书借阅情况             

 借书             

还书            

效果展示


图书借阅管理项目简介

图书管理主要用于对图书馆书籍信息的管理,主要分为以下五个模块:

*,查询模块:该模块主要用于查询现存图书馆中所有书籍的信息,包括书籍名称,作者,出版社,借阅次数

     重点:"select *  from 图书";

               "select * from 图书    order by num desc"

**,查询借阅情况模块:该模块用于用户查询图书的借阅情况,因为借阅情况显示出书内容吸引人的程度,所以特设此模块给借阅者提供借阅参考依据

     重点:

             "select num from 图书    where name='"+q+"'"

***,借书模块:借阅者借书之后系统会给出借阅信息,并在原有的借阅次数上加1,以便后续借阅者查询参考使用   

     重点:"select  num from 图书   where name='"+m+"'"

                "update  图书  set num=? where name=?"

                "select  num from 图书   where name='"+m+"'"

****,还书模块:还书者需要录入所还书籍的所有信息,系统自动判断所还书籍是否已经存在若存在则告诉还书者还书成功,除此之外不做任何操作,若不存在该书籍信息则将该书籍信息增加到图书表中,实时更新表中信息

     重点:"select * from 图书 where name=?"

                "insert into 图书 (name,no,author,publisher) values(?,?,?,?)"

 ******,退出,若借阅者不再进行借还操作则退出系统

项目框架

图书表信息

代码展示

主界面

package tushu.com;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Scanner;

import com.mysql.jdbc.PreparedStatement;

public class TS {
    static String name;
    static String no;
    static String author;
    static String publisher;
    static int num;
    public static void main(String[] args) {
        // TODO Auto-generated method stub
    Connection con;
    String driver="com.mysql.jdbc.Driver";//加载连接数据库所需要的驱动程序
    String url="jdbc:mysql://localhost:3306/图书馆";//指定所要连接数据库
    String user="root";//指定连接数据库的用户
    String password="root";//指定连接数据库的密码
    try {
        Class.forName(driver);//加载连接数据库需要的驱动
        try {
            con=DriverManager.getConnection(url, user, password);//连接数据库
            System.out.println("---------------图书馆借阅查询系统---------------");
            System.out.println("请输入所要进行的业务的代码:\n"+"1,总览图书"+"\t"+"2,借阅情况\n"+"3,借书\t"+"4,还书\n"+"0,退出");
            System.out.println("------------------------------------------");
            Scanner sc=new Scanner(System.in);
            int a=sc.nextInt();
            while(a!=0)
            {
               

查询图书种类


            if(a==1)
            {
            if(!con.isClosed())
            {
              con=DriverManager.getConnection(url, user, password);连接数据库
              Statement statement=con.createStatement();
              String sql="select *  from 图书";//查询数据表中的所有数据
              ResultSet rs=statement.executeQuery(sql);//执行sql语句
              if(!rs.next())
              {
                  System.out.println("暂无图书");
                  a=sc.nextInt();
                  break;
              }
              else
              {
                  String sql1="select * from 图书    order by num desc";//按照图书借阅情况的多少进行降序排序
                  ResultSet rs1=statement.executeQuery(sql1);
                  while(rs1.next())
                  {
                      name=rs1.getString("name");
                      no=rs1.getString("no");
                      author=rs1.getString("author");
                      publisher=rs1.getString("publisher");
                      num=rs1.getInt("num");
                      System.out.println(name+"  "+no+"  "+author+"  "+publisher+"  "+num);
                  }
               }
               }
              a=sc.nextInt();
              }

 查询图书借阅情况
             


            if(a==2)
            {
                System.out.println("请输入所要查询书名");
                String q=sc.next();
                con=DriverManager.getConnection(url, user, password);//连接数据库
                Statement statement=con.createStatement();//创建statement对象执行sql语句
                String sql=new String("select num from 图书    where name='"+q+"'");//显示查询图书的借阅次数
                ResultSet rs=statement.executeQuery(sql);//执行sql语句
                while(rs.next())
                {
                    num=rs.getInt("num");
                    System.out.println("该书共借了"+num+"次");
                }
                a=sc.nextInt();
            }

 借书
             


            if(a==3)
            {
                System.out.println("请输入所要借的书名:");
                String m=sc.next();
                Statement statement=con.createStatement();
                String sql="select  num from 图书   where name='"+m+"'";//显示查询图书的借阅次数
                ResultSet rs=statement.executeQuery(sql);
                while(rs.next())
                {
                  num=rs.getInt("num");
                }
                  int k=num+1;
                java.sql.PreparedStatement ps;
                ps=con.prepareStatement("update  图书  set num=? where name=?");//更新图书表信息
                ps.setInt(1, k);//给sql语句里的第一个形参传值
                ps.setString(2, m);//给sql语句里的第二个形参传值
                ps.executeUpdate();//更新数据表
                String sql1="select  num from 图书   where name='"+m+"'";//显示查询图书的借阅次数
                ResultSet rs1=statement.executeQuery(sql);
                while(rs1.last())
                {
                    System.out.println("该书已借"+rs1.getInt("num")+"次");
                    break;
                }
                a=sc.nextInt();
            }

 

还书
            


            if(a==4)
            {
                Statement statement=con.createStatement();
                System.out.println("请输入所要还的书名:");
                String m=sc.next();
                System.out.println("请输入所还书的编号:");
                String n=sc.next();
                System.out.println("请输入所还书的作者");
                String l=sc.next();
                System.out.println("请输入所还书出版社");
                String p=sc.next();
                 java.sql.PreparedStatement ps;
                int mm=0;
                ResultSet rs=null;
                String sql="select * from 图书 where name=?";//查询还书在数据表里的信息
                ps=con.prepareStatement(sql);//执行sql语句
                ps.setString(1, m);//给sql语句的第一个形参传参
                rs=ps.executeQuery();//不管有无结果集,rs都不为空
                while(rs.next())
                {
                    mm=1;
                    break;
                }
                if(mm==1)
                {
                    System.out.println("还书成功");
                }
                else
                {
                ps=con.prepareStatement("insert into 图书 (name,no,author,publisher) values(?,?,?,?)");
                ps.setString(1, m);
                ps.setString(2, n);
                ps.setString(3, l);
                ps.setString(4, p);
                System.out.println("还书成功");
                ps.executeUpdate();
                }
                a=sc.nextInt();
              }
            }
        }catch (SQLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        } catch (ClassNotFoundException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
      }
     }
}

效果展示

系统介绍 图书管理系统主要的目的是实现图书馆的信息化管理图书馆的主要业务就是新书的借阅和归还,因此系统最核心的功能便是实现图书借阅和归还。此外,还需要提供图书的信息查询、读者图书借阅情况的查询等功能。项目实施后,能够提高图书馆的图书借阅、归还流程,提高工作效率。 操作注意事项 (1)本系统的用户名为:mr,密码为:mrsoft (2)读者类型不同,可借图书的本数也有所区别。 操作流程 (1)用户登录图书管理系统后,可看到图书借阅排行榜,通过排行榜可以看出借阅图书的名称、图书类型、借阅次数等相关信息。 (2)单击“系统设置”/“图书馆信息”命令,对图书馆信息进行设置操作。 (3)单击“系统设置”/“管理员设置”命令,对管理员信息进行添加、权限设置、查询及删除操作。 (4)单击“系统设置”/“参数设置”命令,对办证费用及有效期限信息进行添加操作。 (5)单击“系统设置”/“书架设置”命令,对书架信息进行添加、修改及删除操作。 (6)单击“读者管理”/“读者类型管理”命令,对读者类型信息进行添加、修改及删除操作。 (7)单击“读者管理”/“读者档案管理”命令,对读者信息进行添加、修改及删除操作。 (8)单击“图书管理”/“图书类型设置”命令,对图书类型信息进行添加、修改及删除操作。 (9)单击“图书管理”/“图书档案管理”命令,对图书信息进行添加、修改及删除操作。 (10)单击“图书借还”/“图书借阅”命令,对图书借阅信息添加操作。 (11)单击“图书借还”/“图书续借”命令,对图书续借信息进行添加操作。 (12)单击“图书借还”/“图书归还”命令,对图书归还信息进行添加操作。 (13)单击“系统查询”/“图书档案查询”命令,对图书档案信息进行查询操作。 (14)单击“系统查询”/“图书借阅查询”命令,对借阅图书信息进行查询操作。 (15)单击“系统查询”/“借阅到期提醒”命令,对借阅到期提醒信息进行查询操作。 (16)单击“更改口令”按钮,对当前的用户密码进行修改操作。 (17)单击“退出系统”按钮,退出当前操作系统。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值