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

时间: 2024-01-15 18:04:03 浏览: 36
好的,下面是一个简单的图书管理系统的示例代码,采用三层结构和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

android手机应用源码Imsdroid语音视频通话源码.rar

android手机应用源码Imsdroid语音视频通话源码.rar
recommend-type

营销计划汇报PPT,市场品牌 推广渠道 产品 营销策略tbb.pptx

营销计划汇报PPT,市场品牌 推广渠道 产品 营销策略tbb.pptx
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

【实战演练】增量式PID的simulink仿真实现

# 2.1 Simulink仿真环境简介 Simulink是MATLAB中用于建模、仿真和分析动态系统的图形化环境。它提供了一个直观的用户界面,允许用户使用块和连接线来创建系统模型。Simulink模型由以下元素组成: - **子系统:**将复杂系统分解成更小的、可管理的模块。 - **块:**代表系统中的组件,如传感器、执行器和控制器。 - **连接线:**表示信号在块之间的流动。 Simulink仿真环境提供了广泛的块库,涵盖了各种工程学科,包括控制系统、电子和机械工程。它还支持用户自定义块的创建,以满足特定仿真需求。 # 2. Simulink仿真环境的搭建和建模 ### 2.
recommend-type

训练集和测试集的准确率都99%,但是预测效果不好

即使训练集和测试集的准确率都很高,但是在实际的预测中表现不佳,可能会有以下几个原因: 1. 数据质量问题:模型训练和测试的数据可能存在问题,比如数据标签错误、数据集采样不均衡、数据集中存在异常值等问题,这些问题可能会导致模型在实际预测中表现不佳。 2. 特征工程问题:模型的特征工程可能存在问题,导致模型无法很好地捕捉数据的特征,从而影响预测效果。 3. 模型选择问题:模型的选择可能不合适,比如选择的模型太简单,无法很好地拟合数据,或者选择的模型太复杂,导致过拟合等问题。 4. 超参数调整问题:模型的超参数可能没有调整到最佳状态,需要进行调整。 针对以上可能的原因,可以采取相应的措施进
recommend-type

JSBSim Reference Manual

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