通过java和mongodb数据库写出自行车管理系统的管理员页面、学员页面、自行车页面和查询页面的代码

时间: 2024-01-24 22:17:24 浏览: 19
以下是一个简单的自行车管理系统的Java代码示例,使用MongoDB作为后端数据库。 管理员页面: ```java import java.util.Scanner; import org.bson.Document; import com.mongodb.client.MongoCollection; import com.mongodb.client.MongoDatabase; import static com.mongodb.client.model.Filters.*; public class AdminPage { private MongoDatabase database; private MongoCollection<Document> bikeCollection; public AdminPage(MongoDatabase database) { this.database = database; this.bikeCollection = database.getCollection("bikes"); } public void display() { Scanner scanner = new Scanner(System.in); int choice = -1; while (choice != 0) { System.out.println("1. Add bike"); System.out.println("2. Remove bike"); System.out.println("0. Exit"); System.out.print("Enter your choice: "); choice = scanner.nextInt(); switch(choice) { case 1: addBike(); break; case 2: removeBike(); break; case 0: System.out.println("Exiting..."); break; default: System.out.println("Invalid choice."); } } scanner.close(); } private void addBike() { Scanner scanner = new Scanner(System.in); System.out.print("Enter bike ID: "); int id = scanner.nextInt(); System.out.print("Enter bike name: "); String name = scanner.next(); System.out.print("Enter bike type: "); String type = scanner.next(); System.out.print("Enter bike price: "); double price = scanner.nextDouble(); Document bike = new Document(); bike.append("_id", id) .append("name", name) .append("type", type) .append("price", price); bikeCollection.insertOne(bike); System.out.println("Bike added successfully."); } private void removeBike() { Scanner scanner = new Scanner(System.in); System.out.print("Enter bike ID: "); int id = scanner.nextInt(); bikeCollection.deleteOne(eq("_id", id)); System.out.println("Bike removed successfully."); } } ``` 学员页面: ```java import java.util.Scanner; import org.bson.Document; import com.mongodb.client.MongoCollection; import com.mongodb.client.MongoDatabase; import static com.mongodb.client.model.Filters.*; public class StudentPage { private MongoDatabase database; private MongoCollection<Document> bikeCollection; public StudentPage(MongoDatabase database) { this.database = database; this.bikeCollection = database.getCollection("bikes"); } public void display() { Scanner scanner = new Scanner(System.in); int choice = -1; while (choice != 0) { System.out.println("1. View all bikes"); System.out.println("2. View bike by ID"); System.out.println("0. Exit"); System.out.print("Enter your choice: "); choice = scanner.nextInt(); switch(choice) { case 1: viewAllBikes(); break; case 2: viewBikeById(); break; case 0: System.out.println("Exiting..."); break; default: System.out.println("Invalid choice."); } } scanner.close(); } private void viewAllBikes() { System.out.println("Bikes:"); for(Document doc : bikeCollection.find()) { System.out.println(doc.toJson()); } } private void viewBikeById() { Scanner scanner = new Scanner(System.in); System.out.print("Enter bike ID: "); int id = scanner.nextInt(); Document bike = bikeCollection.find(eq("_id", id)).first(); if (bike != null) { System.out.println(bike.toJson()); } else { System.out.println("Bike not found."); } } } ``` 自行车页面: ```java import java.util.Scanner; import org.bson.Document; import com.mongodb.client.MongoCollection; import com.mongodb.client.MongoDatabase; import static com.mongodb.client.model.Filters.*; public class BikePage { private MongoDatabase database; private MongoCollection<Document> bikeCollection; public BikePage(MongoDatabase database) { this.database = database; this.bikeCollection = database.getCollection("bikes"); } public void display() { Scanner scanner = new Scanner(System.in); int choice = -1; while (choice != 0) { System.out.println("1. View all bikes"); System.out.println("2. View bike by ID"); System.out.println("0. Exit"); System.out.print("Enter your choice: "); choice = scanner.nextInt(); switch(choice) { case 1: viewAllBikes(); break; case 2: viewBikeById(); break; case 0: System.out.println("Exiting..."); break; default: System.out.println("Invalid choice."); } } scanner.close(); } private void viewAllBikes() { System.out.println("Bikes:"); for(Document doc : bikeCollection.find()) { System.out.println(doc.toJson()); } } private void viewBikeById() { Scanner scanner = new Scanner(System.in); System.out.print("Enter bike ID: "); int id = scanner.nextInt(); Document bike = bikeCollection.find(eq("_id", id)).first(); if (bike != null) { System.out.println(bike.toJson()); } else { System.out.println("Bike not found."); } } } ``` 查询页面: ```java import java.util.Scanner; import org.bson.Document; import com.mongodb.client.MongoCollection; import com.mongodb.client.MongoDatabase; import static com.mongodb.client.model.Filters.*; public class QueryPage { private MongoDatabase database; private MongoCollection<Document> bikeCollection; public QueryPage(MongoDatabase database) { this.database = database; this.bikeCollection = database.getCollection("bikes"); } public void display() { Scanner scanner = new Scanner(System.in); int choice = -1; while (choice != 0) { System.out.println("1. Search bikes by name"); System.out.println("2. Search bikes by type"); System.out.println("0. Exit"); System.out.print("Enter your choice: "); choice = scanner.nextInt(); switch(choice) { case 1: searchBikesByName(); break; case 2: searchBikesByType(); break; case 0: System.out.println("Exiting..."); break; default: System.out.println("Invalid choice."); } } scanner.close(); } private void searchBikesByName() { Scanner scanner = new Scanner(System.in); System.out.print("Enter bike name: "); String name = scanner.next(); System.out.println("Bikes:"); for(Document doc : bikeCollection.find(eq("name", name))) { System.out.println(doc.toJson()); } } private void searchBikesByType() { Scanner scanner = new Scanner(System.in); System.out.print("Enter bike type: "); String type = scanner.next(); System.out.println("Bikes:"); for(Document doc : bikeCollection.find(eq("type", type))) { System.out.println(doc.toJson()); } } } ```

相关推荐

最新推荐

recommend-type

JAVA代码实现MongoDB动态条件之分页查询

主要介绍了JAVA如何实现MongoDB动态条件之分页查询,文中讲解非常细致,代码帮助大家更好的理解和学习,感兴趣的朋友可以了解下
recommend-type

java查询mongodb中的objectid示例

主要介绍了java查询mongodb中的objectid示例,需要的朋友可以参考下
recommend-type

浅谈java实现mongoDB的多条件查询

主要介绍了java实现mongoDB的多条件查询,具有一定参考价值,需要的朋友可以参考下。
recommend-type

JAVA mongodb 聚合几种查询方式详解

主要介绍了JAVA mongodb 聚合几种查询方式详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
recommend-type

1亿条记录的MongoDB数据库随机查询性能测试

从测试结果看,当mongodb将数据全部载入到内存后,查询速度根据文档的大小,性能瓶颈通常会是在网络流量和CPU的处理性能(该次测试中当数据全部在内存后,纯粹的查询速度可以稳定在10W/S左右,系统load可以维持在1...
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

list根据id查询pid 然后依次获取到所有的子节点数据

可以使用递归的方式来实现根据id查询pid并获取所有子节点数据。具体实现可以参考以下代码: ``` def get_children_nodes(nodes, parent_id): children = [] for node in nodes: if node['pid'] == parent_id: node['children'] = get_children_nodes(nodes, node['id']) children.append(node) return children # 测试数
recommend-type

JSBSim Reference Manual

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