用java与Mysql写图书管理系统,带注释
时间: 2024-06-08 15:10:41 浏览: 92
基于Java和MySQL语言实现图书管理系统
5星 · 资源好评率100%
好的,以下是用Java和MySQL写图书管理系统的示例代码,附有注释:
```java
import java.sql.*;
import java.util.Scanner;
public class BookManagementSystem {
static final String JDBC_DRIVER = "com.mysql.jdbc.Driver"; // MySQL驱动程序
static final String DB_URL = "jdbc:mysql://localhost/bookstore"; // 数据库URL
static final String USER = "root"; // 数据库用户名
static final String PASS = "password"; // 数据库密码
public static void main(String[] args) {
Connection conn = null;
Statement stmt = null;
try {
Class.forName(JDBC_DRIVER); // 加载MySQL驱动程序
System.out.println("Connecting to database...");
conn = DriverManager.getConnection(DB_URL, USER, PASS); // 连接数据库
System.out.println("Creating statement...");
stmt = conn.createStatement(); // 创建Statement对象
Scanner scanner = new Scanner(System.in);
while (true) {
System.out.println("1.添加图书 2.查询图书 3.删除图书 4.退出");
int option = scanner.nextInt();
switch (option) {
case 1:
addBook(conn, scanner); // 调用添加图书函数
break;
case 2:
queryBook(stmt, scanner); // 调用查询图书函数
break;
case 3:
deleteBook(conn, scanner); // 调用删除图书函数
break;
case 4:
System.exit(0); // 退出程序
break;
default:
System.out.println("无效的选项");
break;
}
}
} catch (SQLException se) {
se.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
} finally {
try {
if (stmt != null) stmt.close();
} catch (SQLException se2) {
}
try {
if (conn != null) conn.close();
} catch (SQLException se) {
se.printStackTrace();
}
}
System.out.println("Goodbye!");
}
/**
* 添加图书函数
*/
private static void addBook(Connection conn, Scanner scanner) throws SQLException {
System.out.println("请输入图书编号:");
int id = scanner.nextInt();
System.out.println("请输入图书名称:");
String name = scanner.next();
System.out.println("请输入图书价格:");
int price = scanner.nextInt();
String sql = "INSERT INTO books VALUES (" + id + ", '" + name + "', " + price + ")";
int result = conn.createStatement().executeUpdate(sql); // 执行插入语句
if (result > 0) {
System.out.println("添加图书成功");
} else {
System.out.println("添加图书失败");
}
}
/**
* 查询图书函数
*/
private static void queryBook(Statement stmt, Scanner scanner) throws SQLException {
System.out.println("请输入查询关键字:");
String keyword = scanner.next();
String sql = "SELECT * FROM books WHERE book_name LIKE '%" + keyword + "%'";
ResultSet rs = stmt.executeQuery(sql); // 执行查询语句
while (rs.next()) { // 遍历结果集
int id = rs.getInt("book_id");
String name = rs.getString("book_name");
int price = rs.getInt("price");
System.out.println(id + " " + name + " " + price);
}
rs.close(); // 关闭结果集
}
/**
* 删除图书函数
*/
private static void deleteBook(Connection conn, Scanner scanner) throws SQLException {
System.out.println("请输入要删除的图书编号:");
int id = scanner.nextInt();
String sql = "DELETE FROM books WHERE book_id = " + id;
int result = conn.createStatement().executeUpdate(sql); // 执行删除语句
if (result > 0) {
System.out.println("删除图书成功");
} else {
System.out.println("删除图书失败");
}
}
}
```
这段代码实现了一个基本的图书管理系统,用户可以选择添加、查询和删除图书。其中,使用了Java JDBC API连接MySQL数据库,并用注释解释了每个函数的作用。注意,在使用此代码之前,你需要先在MySQL数据库中创建一个名为“bookstore”的数据库,并在其中创建一个名为“books”的表。表结构如下:
```
CREATE TABLE books (
book_id INT NOT NULL,
book_name VARCHAR(50) NOT NULL,
price INT NOT NULL,
PRIMARY KEY (book_id)
);
```
另外,使用这段代码需要导入MySQL JDBC驱动程序,具体方法可以参考[这篇文章](https://www.runoob.com/java/java-mysql-connect.html)。
阅读全文