17370845950

如何使用Java实现商品价格查询功能
答案是使用HashMap存储商品信息并提供按ID查询价格的方法。定义Product类封装商品属性,通过PriceQueryService将商品ID作为键存入HashMap实现高效查找,提供getPriceById方法返回价格,支持按名称模糊查询,并可在主程序中调用验证结果,适用于简单场景,复杂应用可结合数据库扩展。

要实现商品价格查询功能,核心是设计合理的数据结构和查询逻辑。Java提供了多种方式来完成这项任务,下面从数据存储、查询方法到实际代码一步步说明。

1. 定义商品类

每个商品应包含名称、编号和价格等基本信息。创建一个简单的POJO类来表示商品。

public class Product {
    private String id;
    private String name;
    private double price;

    public Product(String id, String name, double price) {
        this.id = id;
        this.name = name;
        this.price = price;
    }

    // Getter方法
    public String getId() { return id; }
    public String getName() { return name; }
    public double getPrice() { return price; }

    @Override
    public String toString() {
        return "Product{" +
                "id='" + id + '\'' +
                ", name='" + name + '\'' +
                ", price=" + price +
                '}';
    }
}

2. 使用Map存储商品信息

使用HashMap以商品ID为键存储商品,能实现快速查找。这是最常见且高效的方式。

import java.util.HashMap;
import java.util.Map;

public class PriceQueryService {
    private Map productMap;

    public PriceQueryService() {
        productMap = new HashMap<>();
        // 模拟初始化数据
        productMap.put("P001", new Product("P001", "笔记本电脑", 5999.0));
        productMap.put("P002", new Product("P002", "无线鼠标", 129.0));
        productMap.put("P003", new Product("P003", "机械键盘", 499.0));
    }
}

3. 实现价格查询方法

提供按商品ID查询价格的方法,返回结果可以是价格值或完整商品对象,也可处理不存在的情况。

    public Double getPriceById(String productId) {
        Product product = productMap.get(productId);
        if (product != null) {
            return product.getPrice();
        } else {
            return null; // 或抛出自定义异常
        }
    }

    public Product getProductById(String productId) {
        return productMap.get(productId);
    }

在主程序中调用:

public class Main {
    public static void main(String[] args) {
        PriceQueryService service = new PriceQueryService();

        String targetId = "P001";
        Double price = service.getPriceById(targetId);

        if (price != null) {
            System.out.println("商品价格: " + price);
        } else {
            System.out.println("商品未找到");
        }
    }
}

4. 扩展:支持按名称模糊查询

若需根据商品名称查找,可遍历map的值集合,使用contains进行模糊匹配。

    public List getProductsByName(String keyword) {
        return productMap.values().stream()
                .filter(p -> p.getName().contains(keyword))
                .collect(Collectors.toList());
    }

调用示例:

List results = service.getProductsByName("鼠标");
results.forEach(System.out::println);
提示:对于更复杂场景,可结合数据库(如MySQL)+ JDBC或使用Spring Boot整合MyBatis/JPA实现持久化查询。 基本上就这些。用Java做价格查询,关键是选对数据结构,再封装清晰的查询接口,后续扩展也方便。