1

我是java新手。我有一个具有以下复合键的数据库表:

Code
Reference_Number_1 (decimal)
Reference_Number_2 (decimal)
Time

上面的键使每一行成为唯一的行 - 没有重复。我需要创建一个类来将此表加载到 java 集合并创建一个静态方法,该方法将上述四个参数作为键并从 java 集合返回实体。

我正在考虑将表加载到 HashMap 中,但我不确定如何定义 MapKey。我是否应该将 Reference_Number_1、Reference_Number_2 和 Time 转换为字符串,然后将这四个字段连接起来?或者还有另一种方式/集合来加载这个表。谢谢,皮特

4

2 回答 2

6

创建另一个类,该类将这 4 个字段作为属性并实现/自动生成equals()hashCode() 根据合同(重要!否则它不能用作正确的Map键),最后将其用作Map.

以下是 Eclipse 为我自动生成的内容(equals()有待改进,有点冗长):

public class CompositeKey {

    private String code;
    private BigDecimal referenceNumber1;
    private BigDecimal referenceNumber2;
    private Date time;

    public CompositeKey(String code, BigDecimal referenceNumber1, BigDecimal referenceNumber2, Date time) {
        this.code = code;
        this.referenceNumber1 = referenceNumber1;
        this.referenceNumber2 = referenceNumber2;
        this.time = time;
    }

    public String getCode() {
        return code;
    }

    public BigDecimal getReferenceNumber1() {
        return referenceNumber1;
    }

    public BigDecimal getReferenceNumber2() {
        return referenceNumber2;
    }

    public Date getTime() {
        return time;
    }

    @Override
    public boolean equals(Object obj) {
        if (this == obj)
            return true;
        if (obj == null)
            return false;
        if (getClass() != obj.getClass())
            return false;
        CompositeKey other = (CompositeKey) obj;
        if (code == null) {
            if (other.code != null)
                return false;
        }
        else if (!code.equals(other.code))
            return false;
        if (referenceNumber1 == null) {
            if (other.referenceNumber1 != null)
                return false;
        }
        else if (!referenceNumber1.equals(other.referenceNumber1))
            return false;
        if (referenceNumber2 == null) {
            if (other.referenceNumber2 != null)
                return false;
        }
        else if (!referenceNumber2.equals(other.referenceNumber2))
            return false;
        if (time == null) {
            if (other.time != null)
                return false;
        }
        else if (!time.equals(other.time))
            return false;
        return true;
    }

    @Override
    public int hashCode() {
        final int prime = 31;
        int result = 1;
        result = prime * result + ((code == null) ? 0 : code.hashCode());
        result = prime * result + ((referenceNumber1 == null) ? 0 : referenceNumber1.hashCode());
        result = prime * result + ((referenceNumber2 == null) ? 0 : referenceNumber2.hashCode());
        result = prime * result + ((time == null) ? 0 : time.hashCode());
        return result;
    }

}
于 2012-07-01T19:51:04.320 回答
2

将这四个字段封装在一个对象中:

public class Key {
    String code;
    float reference1;
    float reference2;
    Date time;

    public Key(String code, float ref1, float ref2, Date time) {
        ...
    }

    // implement equals() and hashCode()
}

然后定义 aMap如下(不确定“实体”是什么类型,所以我们假设有一个名为 的类Entity

Map<Key, Entity> lookup = new HashMap<Key, Entity>();

于 2012-07-01T19:51:40.457 回答