数据库测试1

This commit is contained in:
GuanM 2024-10-23 15:16:11 +08:00
parent 5998a21023
commit 30c9e6f98f
2 changed files with 38 additions and 96 deletions

View File

@ -59,4 +59,3 @@ public class DatabaseManager {
} }
} }
} }

View File

@ -1,118 +1,61 @@
package TodoListApp.src; package TodoListApp.src;
import java.io.File;
import java.io.FileOutputStream; import java.sql.SQLException;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List; import java.util.List;
import java.time.LocalDateTime;
import java.time.format.DateTimeFormatter; public class TodoListManager {
// 待办事项管理类 private DatabaseManager dbManager;
class TodoListManager {
private final List<TodoItem> todoList;
private int nextId;
// private DatabaseManager dbManager; // 暂时注释掉
public TodoListManager() { public TodoListManager() {
todoList = new ArrayList<>(); dbManager = new DatabaseManager();
nextId = 1; // 起始编号
// dbManager = new DatabaseManager(); //
} }
// 添加待办事项 public void addTodo(String description) throws EmptyDescriptionException {
public void addTodo(String description) throws EmptyDescriptionException{ //同时声明可能抛出的异常类型 if (description == null || description.trim().isEmpty()) {
if(description == null || description.trim().isEmpty()){ throw new EmptyDescriptionException("待办事项描述不能为空。");
EmptyDescriptionException e = new EmptyDescriptionException("待办事项的描述不能为空。"); }
throw e; try {
dbManager.addTodo(description);
System.out.println("待办事项已添加。");
} catch (SQLException e) {
System.out.println("添加待办事项时发生错误:" + e.getMessage());
} }
TodoItem item = new TodoItem(nextId++, description);
todoList.add(item);
System.out.println("待办事项已添加: " + item);
} }
// 列出所有待办事项
public void listTodos() { public void listTodos() {
if (todoList.isEmpty()) { try {
System.out.println("当前没有待办事项。"); List<TodoItem> todos = dbManager.getAllTodos();
return; if (todos.isEmpty()) {
} System.out.println("没有待办事项。");
System.out.println("\n===== 待办事项列表 ====="); } else {
for (TodoItem item : todoList) { for (TodoItem todo : todos) {
System.out.println(item); System.out.println(todo);
}
}
} catch (SQLException e) {
System.out.println("获取待办事项列表时发生错误:" + e.getMessage());
} }
} }
// 删除指定编号的待办事项 public void removeTodo(int id) throws TodoNotFoundException {
public void removeTodo(int id) throws TodoNotFoundException{ try {
boolean removed = false; dbManager.removeTodo(id);
for (TodoItem item : todoList) { System.out.println("待办事项已删除。");
if (item.getId() == id) { } catch (SQLException e) {
todoList.remove(item); throw new TodoNotFoundException("未找到ID为 " + id + " 的待办事项。");
System.out.println("已删除待办事项: " + item);
removed = true;
break;
}
}
if (!removed) {
throw new TodoNotFoundException("未找到编号为 " + id + " 的待办事项。");
//System.out.println("未找到编号为 " + id + " 的待办事项。");
} }
} }
public void markAsCompleted(int id) { public void markAsCompleted(int id) {
TodoItem item = null;
for (TodoItem todo : todoList) {
if (todo.getId() == id) {
item = todo;
break;
}
}
if (item != null) {
if (!item.isCompleted()) {
item.setCompleted(true);
System.out.println("待办事项已标记为完成: " + item);
} else {
System.out.println("待办事项已完成,无需重复标记。");
}
}
else {
System.out.println("未找到编号为:" + id + " 的待办事项。");
}
}
public void saveToFile(String filename){
try { try {
File file = new File(filename); dbManager.markAsCompleted(id);
FileOutputStream fos = new FileOutputStream(file); System.out.println("待办事项已标记为完成。");
} catch (SQLException e) {
for (TodoItem item : todoList) { System.out.println("标记待办事项时发生错误:" + e.getMessage());
String line = item.getId() + ":" + item.getDescription() + "\n";
fos.write(line.getBytes());
}
System.out.println("待办事项已经保存到文件:" + filename);
fos.close();
}
catch (IOException e){
System.out.println("待办事项保存失败:" + e.getMessage());
} }
} }
private void backupToFile(String backupFilename) { public void saveToFile(String filename) {
LocalDateTime now = LocalDateTime.now(); System.out.println("数据已保存在数据库中,无需额外保存到文件。");
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd_HH-mm-ss");
String timestamp = now.format(formatter);
String fullBackupFilename = backupFilename + "_" + timestamp + ".bak";
try (FileOutputStream fos = new FileOutputStream(new File(fullBackupFilename))) {
for (TodoItem item : todoList) {
String line = item.getId() + ":" + item.getDescription() + ":" + (item.isCompleted() ? "完成" : "未完成") + "\n";
fos.write(line.getBytes());
}
System.out.println("待办事项已备份到文件:" + fullBackupFilename);
} catch (IOException e) {
System.out.println("待办事项备份失败:" + e.getMessage());
}
} }
} }