0

您好我正在创建一个应用程序,我可以在其中将数据存储在购物车模块的 Hashmap 和列表中。但我想从我的 MS-Access 数据库中获取这些数据。我尝试了以下代码,但它没有编译。请给我指导.

代码:

import java.sql.*;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;

public class Program {
    public static void main(String [] args){}

    public static HashMap getProductsAsMap() {
        try {
            Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
            Connection con = DriverManager.getConnection("jdbc:odbc:pd");
            ResultSet rs = null;
            Statement st = con.createStatement();
            String sql = ("select * from products");
            rs=st.executeQuery(sql);
            while (rs.next()) { 
                HashMap<String, ProductBean> products= new HashMap<String, ProductBean>();
                String name=rs.getString("pname");
                String desc=rs.getString("pdesc");
                String image=rs.getString("pimage");
                products.put("P1", new ProductBean(name,desc,image));
                return products;
            }
            rs.close();
            st.close();
            con.close();
        }
        catch(Exception e){}   
    }

    public static List getProductsAsList() {
        List<ProductBean> products = new ArrayList<ProductBean>();
        try {
            Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
            Connection con = DriverManager.getConnection("jdbc:odbc:pd");
            ResultSet rs = null;
            Statement st = con.createStatement();
            String sql = ("select * from products");
            rs=st.executeQuery(sql);
            while (rs.next()) { 
                String name=rs.getString("pname");
                String desc=rs.getString("pdesc");
                String image=rs.getString("pimage");
                products.add(new ProductBean(name,desc,image));
            }
            rs.close();
            st.close();
            con.close();
        }
        catch(Exception e){}
        return products;  
    }
}

我得到2个错误如下:

在此处输入图像描述

4

3 回答 3

2

您的ProductBean类没有将三个字符串作为参数的构造函数。

于 2012-09-15T11:41:21.667 回答
1

如错误所示,该类ProductBean缺少带有 3 个字符串 - 签名的构造函数ProductBean(String, String, String)

再次检查此类以匹配现有构造函数,或添加新构造函数以匹配您的代码。

于 2012-09-15T11:41:14.193 回答
0

它应该是这样的:

products.add(bean)

bean 是ProductBean类 ProductBean 的对象 bean = new ProductBean();

于 2013-07-29T19:05:41.707 回答