我想将类型为arrayList的产品的值插入数据库,但出现此错误"java.lang.String cannot be cast to model.Product"
。问题出在我在servlet中执行的强制转换。这是它的代码:
String buyer = request.getParameter("buyer");
List<String> prodlist = Arrays.asList(request.getParameterValues("product"));
List<Product> prodmlist = (List<Product>) (List<?>) prodlist;
Bill bill = new Bill(buyer, prodmlist);
myDAO.add(bill);
这是将要填充的方法
public static void add(Bill bill) {
Connection cnx;
try {
cnx = Connect.getConnection();
String req = "insert into bil values (?,?)";
PreparedStatement st = cnx.prepareStatement(req);
st.setString(1, bill.getBuyer());
for (Product prod : bill.getProduct()) {
st.setString(2, prod.getName());
st.addBatch(); // add the statement to the batch
}
st.executeUpdate();
cnx.commit();
}
答案 0 :(得分:0)
在您的代码中:
@supports
您需要从List<String> prodlist = Arrays.asList(request.getParameterValues("product"));
// Need to convert here...
List<Product> prodmlist = (List<Product>) (List<?>) prodlist;
显式转换为List<String>
。按照以下方式进行操作:
List<Product>
现在,我假设您有一个设置员来设置“产品”上的名称。可能是您有一个构造函数,可以将名称传递给该构造函数(并保存一行代码)。
答案 1 :(得分:-1)
您不能将列表从一种类型转换为另一种类型。如果要“更改类型”,则必须将其转换:
使用Java 8 lambda:
listReceived.forEach(string -> listProduct.add(new Product(string)));
常规方式:
for (String string : listReceived) {
listProduct.add(new Product(string));
}
我假设您的类Product具有接受字符串的构造函数。如果没有,则应解析该字符串并实现循环中产品的每个成员。
// expecting that all information are separated by a space
Product product = new Product();
String[] splittedString = string.split(" ");
product.name = splittedString[0];
....
listProduct.add(product);