利用三层结构+JDBC开发一个简单的图书管理系统

时间: 2024-01-15 22:04:03 浏览: 31
好的,下面是一个简单的图书管理系统的示例代码,采用三层结构和JDBC技术实现。 首先,我们需要创建一个数据库,并且创建一个名为books的表,用于存储图书信息。表的结构如下: ``` CREATE TABLE books ( id INT(11) NOT NULL AUTO_INCREMENT, name VARCHAR(50) NOT NULL, author VARCHAR(50) NOT NULL, price DOUBLE NOT NULL, PRIMARY KEY (id) ); ``` 接下来,我们需要编写对数据库的基本操作,包括连接数据库、关闭数据库、查询图书信息、添加图书信息、修改图书信息和删除图书信息等。 下面是一个简单的JDBC工具类,用于连接数据库和执行SQL语句: ```java package com.example.bookstore.util; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; public class JDBCUtil { private static final String DRIVER_CLASS = "com.mysql.jdbc.Driver"; private static final String DB_URL = "jdbc:mysql://localhost:3306/bookstore"; private static final String DB_USER = "root"; private static final String DB_PASSWORD = "root"; public static Connection getConnection() { Connection conn = null; try { Class.forName(DRIVER_CLASS); conn = DriverManager.getConnection(DB_URL, DB_USER, DB_PASSWORD); } catch (ClassNotFoundException | SQLException e) { e.printStackTrace(); } return conn; } public static void closeConnection(Connection conn, PreparedStatement ps, ResultSet rs) { if (rs != null) { try { rs.close(); } catch (SQLException e) { e.printStackTrace(); } } if (ps != null) { try { ps.close(); } catch (SQLException e) { e.printStackTrace(); } } if (conn != null) { try { conn.close(); } catch (SQLException e) { e.printStackTrace(); } } } } ``` 然后,我们需要编写一个Book类,用于封装图书信息: ```java package com.example.bookstore.model; public class Book { private int id; private String name; private String author; private double price; public Book() {} public Book(int id, String name, String author, double price) { this.id = id; this.name = name; this.author = author; this.price = price; } // 省略getter和setter方法 } ``` 接下来,我们需要编写一个BookDAO类,用于实现对图书信息的增删改查操作: ```java package com.example.bookstore.dao; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.util.ArrayList; import java.util.List; import com.example.bookstore.model.Book; import com.example.bookstore.util.JDBCUtil; public class BookDAO { public void addBook(Book book) { Connection conn = null; PreparedStatement ps = null; try { conn = JDBCUtil.getConnection(); String sql = "INSERT INTO books (name, author, price) VALUES (?, ?, ?)"; ps = conn.prepareStatement(sql); ps.setString(1, book.getName()); ps.setString(2, book.getAuthor()); ps.setDouble(3, book.getPrice()); ps.executeUpdate(); } catch (SQLException e) { e.printStackTrace(); } finally { JDBCUtil.closeConnection(conn, ps, null); } } public void deleteBook(int id) { Connection conn = null; PreparedStatement ps = null; try { conn = JDBCUtil.getConnection(); String sql = "DELETE FROM books WHERE id = ?"; ps = conn.prepareStatement(sql); ps.setInt(1, id); ps.executeUpdate(); } catch (SQLException e) { e.printStackTrace(); } finally { JDBCUtil.closeConnection(conn, ps, null); } } public void updateBook(Book book) { Connection conn = null; PreparedStatement ps = null; try { conn = JDBCUtil.getConnection(); String sql = "UPDATE books SET name = ?, author = ?, price = ? WHERE id = ?"; ps = conn.prepareStatement(sql); ps.setString(1, book.getName()); ps.setString(2, book.getAuthor()); ps.setDouble(3, book.getPrice()); ps.setInt(4, book.getId()); ps.executeUpdate(); } catch (SQLException e) { e.printStackTrace(); } finally { JDBCUtil.closeConnection(conn, ps, null); } } public List<Book> listBooks() { List<Book> books = new ArrayList<>(); Connection conn = null; PreparedStatement ps = null; ResultSet rs = null; try { conn = JDBCUtil.getConnection(); String sql = "SELECT * FROM books"; ps = conn.prepareStatement(sql); rs = ps.executeQuery(); while (rs.next()) { int id = rs.getInt("id"); String name = rs.getString("name"); String author = rs.getString("author"); double price = rs.getDouble("price"); Book book = new Book(id, name, author, price); books.add(book); } } catch (SQLException e) { e.printStackTrace(); } finally { JDBCUtil.closeConnection(conn, ps, rs); } return books; } public Book getBook(int id) { Book book = null; Connection conn = null; PreparedStatement ps = null; ResultSet rs = null; try { conn = JDBCUtil.getConnection(); String sql = "SELECT * FROM books WHERE id = ?"; ps = conn.prepareStatement(sql); ps.setInt(1, id); rs = ps.executeQuery(); if (rs.next()) { String name = rs.getString("name"); String author = rs.getString("author"); double price = rs.getDouble("price"); book = new Book(id, name, author, price); } } catch (SQLException e) { e.printStackTrace(); } finally { JDBCUtil.closeConnection(conn, ps, rs); } return book; } } ``` 最后,我们可以编写一个简单的控制台程序,用于测试BookDAO类的功能: ```java package com.example.bookstore; import java.util.List; import java.util.Scanner; import com.example.bookstore.dao.BookDAO; import com.example.bookstore.model.Book; public class BookStore { public static void main(String[] args) { BookDAO bookDAO = new BookDAO(); Scanner scanner = new Scanner(System.in); while (true) { System.out.println("请选择操作:"); System.out.println("1. 添加图书"); System.out.println("2. 删除图书"); System.out.println("3. 修改图书"); System.out.println("4. 查询图书"); System.out.println("5. 退出程序"); String choice = scanner.nextLine(); switch (choice) { case "1": System.out.println("请输入图书名称:"); String name = scanner.nextLine(); System.out.println("请输入图书作者:"); String author = scanner.nextLine(); System.out.println("请输入图书价格:"); double price = scanner.nextDouble(); scanner.nextLine(); Book book = new Book(0, name, author, price); bookDAO.addBook(book); System.out.println("添加成功!"); break; case "2": System.out.println("请输入图书ID:"); int id = scanner.nextInt(); scanner.nextLine(); bookDAO.deleteBook(id); System.out.println("删除成功!"); break; case "3": System.out.println("请输入图书ID:"); int id2 = scanner.nextInt(); scanner.nextLine(); Book book2 = bookDAO.getBook(id2); if (book2 == null) { System.out.println("图书不存在!"); } else { System.out.println("请输入图书名称(原名称:" + book2.getName() + "):"); String name2 = scanner.nextLine(); System.out.println("请输入图书作者(原作者:" + book2.getAuthor() + "):"); String author2 = scanner.nextLine(); System.out.println("请输入图书价格(原价格:" + book2.getPrice() + "):"); double price2 = scanner.nextDouble(); scanner.nextLine(); book2.setName(name2); book2.setAuthor(author2); book2.setPrice(price2); bookDAO.updateBook(book2); System.out.println("修改成功!"); } break; case "4": List<Book> books = bookDAO.listBooks(); if (books.isEmpty()) { System.out.println("暂无图书信息!"); } else { for (Book b : books) { System.out.println(b.getId() + " " + b.getName() + " " + b.getAuthor() + " " + b.getPrice()); } } break; case "5": scanner.close(); System.exit(0); break; default: System.out.println("输入有误,请重新输入!"); break; } } } } ``` 以上就是一个简单的图书管理系统的示例代码,采用了三层结构和JDBC技术实现。

相关推荐

最新推荐

recommend-type

JDBC+GUI实现简单学生管理系统

主要为大家详细介绍了JDBC+GUI实现简单学生管理系统,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

javaee 实验报告 实验一 JSP+Servlet+Javabean+jdbc-基于MVC模式的数据库的应用

实验一 JSP+Servlet+Javabean+jdbc-基于MVC模式的数据库的应用 实验二 JSF+JPA实现用户注册 实验三 struts+spring+hibernate框架访问数据库的应用 实验四 使用WebService和EJBean访问数据库的应用
recommend-type

java控制台输出图书馆管理系统

主要为大家详细介绍了java控制台输出图书馆管理系统,只用java代码不用数据库和GUI等,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

node-v4.1.0-linux-x64.tar.xz

Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。
recommend-type

基于AT89S52的数字温度计设计说明.docx

基于AT89S52的数字温度计设计说明.docx
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

spring添加xml配置文件

1. 创建一个新的Spring配置文件,例如"applicationContext.xml"。 2. 在文件头部添加XML命名空间和schema定义,如下所示: ``` <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.springframework.org/schema/beans
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。