写一个Java程序,创建一个名为Books的数据库,并在其中建立一个名为book_message的表,字段包括书名、作者、出版社、出版时间和价格。编写一个应用程序,用预处理方式在该数据库中实现增加、删除和修改数据以及查询的基本功能。
时间: 2024-02-17 22:04:45 浏览: 93
好的,以下是一个简单的Java程序,用于创建名为Books的数据库,并在其中创建一个名为book_message的表,同时实现增加、删除和修改数据以及查询的基本功能:
```java
import java.sql.*;
public class BooksDatabase {
static final String JDBC_DRIVER = "com.mysql.jdbc.Driver";
static final String DB_URL = "jdbc:mysql://localhost/Books";
static final String USER = "username";
static final String PASS = "password";
public static void main(String[] args) {
Connection conn = null;
Statement stmt = null;
try {
Class.forName(JDBC_DRIVER);
conn = DriverManager.getConnection(DB_URL, USER, PASS);
stmt = conn.createStatement();
String sql = "CREATE TABLE book_message " +
"(id INTEGER not NULL AUTO_INCREMENT, " +
" book_name VARCHAR(255), " +
" author VARCHAR(255), " +
" publisher VARCHAR(255), " +
" publish_time DATE, " +
" price FLOAT, " +
" PRIMARY KEY ( id ))";
stmt.executeUpdate(sql);
System.out.println("Created table in given database...");
// 增加数据
sql = "INSERT INTO book_message (book_name, author, publisher, publish_time, price) " +
"VALUES ('The Da Vinci Code', 'Dan Brown', 'Doubleday', '2003-03-18', 25.00)";
stmt.executeUpdate(sql);
// 查询数据
sql = "SELECT id, book_name, author, publisher, publish_time, price FROM book_message";
ResultSet rs = stmt.executeQuery(sql);
// 输出查询结果
while (rs.next()) {
int id = rs.getInt("id");
String bookName = rs.getString("book_name");
String author = rs.getString("author");
String publisher = rs.getString("publisher");
Date publishTime = rs.getDate("publish_time");
float price = rs.getFloat("price");
System.out.print("id: " + id);
System.out.print(", book name: " + bookName);
System.out.print(", author: " + author);
System.out.print(", publisher: " + publisher);
System.out.print(", publish time: " + publishTime);
System.out.println(", price: " + price);
}
// 删除数据
sql = "DELETE FROM book_message WHERE book_name = 'The Da Vinci Code'";
stmt.executeUpdate(sql);
// 修改数据
sql = "UPDATE book_message SET price = 20.00 WHERE book_name = 'The Da Vinci Code'";
stmt.executeUpdate(sql);
rs.close();
stmt.close();
conn.close();
} 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!");
}
}
```
请注意,此程序使用MySQL作为数据库,因此您需要安装MySQL并在本地运行它。您还需要将程序中的用户名和密码替换为您自己的MySQL用户名和密码。
此程序使用预处理方式避免SQL注入攻击。如果您想更详细地了解预处理语句的工作原理,请参阅Java官方文档。
阅读全文