0

ハッシュ マップのハッシュ マップにデータをロードしようとしていますが、null ポインターを取得し続け、正しいことを行っているかどうかわかりません。

ハッシュ マップを SalesAreaCode、年、および製品の 3 つのキーに基づいて作成したいと考えています。残りはarraylistに保存したい。販売地域コード、年、製品を渡し、顧客、数量、価格など、これら 3 つのキーに関連するすべての製品を一覧表示したいと考えています。どんな助けでも大歓迎です!! アラン

コード:

 public HashMap<String, HashMap<String, HashMap<String, ArrayList<Sales>>>> getSalesDetails(Connection con)
{
        HashMap<String, HashMap<String, HashMap<String, ArrayList<Sales>>>>> hmpSales =
        new  HashMap<String, HashMap<String, HashMap<String, ArrayList<Sales>>>>>();
        Sales s;
        HashMap<String,ArrayList<Sales>> hmpSalProd = new HashMap<String, ArrayList<Sales>>();
        HashMap<String,HashMap<String,ArrayList<Sales>>> hmpSalYear = 
        new HashMap<String, ArrayList<Sales>>>();    

       try
       {
             pst = con.prepareStatement(sql);
       rs=pst.executeQuery();
       while(rs.next())
       {
                  s=new Sales();

                  if(!(hmpSalProd.containskey(rs.getString("product"))))
                  {
                       s.setSalesCode(rs.getString("sacd"));
                       s.setCustomerCode(rs.getString("custcd"));
                       s.setYear(rs.getInt("year"));
                       s.setProduct(rs.getString("product"));
                       s.setPrice(rs.getDouble("price"));
                       s.setQty(rs.getInt("qty"));
                       hmpSalProd.put(rs.getString("product"),
                       new ArrayList<Sales>(Arrays.asList(s)));
                  }
                  else
                  {
                      s.setSalesCode(rs.getString("sacd"));
                      s.setCustomerCode(rs.getString("custcd"));
                      s.setYear(rs.getInt("year"));
                      s.setProduct(rs.getString("product"));
                      s.setPrice(rs.getDouble("price"));
                      s.setQty(rs.getInt("qty"));
                      hmpSalProd.get(rs.getString("product")).add(s);
                  }
                  if(!(hmpSalYear.containsKey(String.valueOf(rs.getInt("year")))))
                  {
                      hmpSalYear.put(String.valueOf(rs.getInt("year")),hmpSalProd);
                  }
                  else
                  {
                      hmpSalYear.get(String.valueOf(rs.getInt("year"))).
                      get(rs.getString("product")).add(s);
                  }

                  if(!(hmpSalArea.containsKey(rs.getString("sacd"))))
                  {
                     hmpSales.put(rs.getString("sacd"),hmpSalYear);
                  }
                  else
                  {
                      hmpSales.get(rs.getString("sacd")).
                      get(String.valueOf(rs.getInt("year"))).
                      get(rs.getString("product")).add(s);
                  }

          }
          pst.close();
          rs.close();
     }
     catch(SQLException se)
     {
           System.out.println("error loading: " + se.getMessage());
     }
     return hmpSales;

}          
4

1 に答える 1

0

2 つのクラスを定義することをお勧めします。

  • SalesKeySalesAreaCode、年、および製品を格納し、equals および hashCode をオーバーライドし、変更不可 (一度作成された値を変更する方法はありません)
  • 販売キーにマップされるデータを格納するSalesDataクラス (SalesAreaCode、年、および製品を含む)。

その後、を使用できるようになりますMap<SalesKey, SalesData>。その方が理解しやすいので、達成したいことを簡単に実装できます。

于 2013-01-14T11:27:56.260 に答える