Java - ¿Arraylists mixtas?
-
22-10-2019 - |
Pregunta
¿Es posible almacenar una mezcla de tipos de objetos en una lista de matrices? ¿Si es así, cómo?
Esto es lo que he probado hasta ahora:
List<Object> list = new ArrayList<Object>();
list.add(new String("Hello World"));
list.add(new Integer(1));
list.add(new Long(1l));
for (i = 0; i < list.size(); i++) {
if (list.get(i) instanceof String){
sqlPreparedStatement.setString((i+1), (String) list.get(i));
} else if (list.get(i) instanceof Integer) {
sqlPreparedStatement.setInt((i+1), (Integer) list.get(i));
} else if (list.get(i) instanceof Long) {
sqlPreparedStatement.setLong((i+1), (Long) list.get(i));
}
}
Pero lanza una excepción de casting.
¡Gracias por adelantado por cualquier contribución!
Solución
Esto es lo que debes tener:
List<Object> list = new ArrayList<Object>();
list.add(new String("Hello World"));
list.add(new Integer(1));
list.add(new Long(1l));
for (Object obj: list) {
if (obj instanceof String){
sqlPreparedStatement.setString((String) obj);
} else if (obj instanceof Integer) {
sqlPreparedStatement.setInt((Integer) obj);
} else if (obj instanceof Long) {
sqlPreparedStatement.setLong((Long) obj);
}
}
Otros consejos
Lamento bloquear su desfile, pero no debería usar una lista de matrices de 3 (o cualquiera) diferentes tipos para empezar. Si la información está relacionada, cree una clase que contenga la información relacionada y cree una lista de matrices que contenga solo un tipo: objetos de esta clase.
Editar 1:
Por ejemplo, diga una clase para mantener los datos de así:
class SqlData {
private String textData;
private int intData;
private long longData;
public SqlData(String textData, int intData, long longData) {
this.textData = textData;
this.intData = intData;
this.longData = longData;
}
public String getTextData() {
return textData;
}
public int getIntData() {
return intData;
}
public long getLongData() {
return longData;
}
}
y usado así:
List<SqlData> sqlDataList = new ArrayList<SqlData>();
sqlDataList.add(new SqlData("Hello World", 1, 11L));
for (int i = 0; i < sqlDataList.size(); i++) {
try {
sqlPreparedStatement.setString(i + 1, sqlDataList.get(i).getTextData());
sqlPreparedStatement.setInt(i + 1, sqlDataList.get(i).getIntData());
sqlPreparedStatement.setLong(i + 1, sqlDataList.get(i).getLongData());
} catch (SQLException e) {
e.printStackTrace();
}
}
¿Por qué estás haciendo esto tan difícil? PreparedStatement
tiene un setObject()
Método: solo use eso:
List<Object> list = new ArrayList<Object>();
list.add(new String("Hello World"));
list.add(new Integer(1));
list.add(new Long(1l));
for (int i = 0; i < list.size(); i++)
sqlPreparedStatement.setObject(i + 1, list.get(i)); // NOTE: columns count from 1
Nota: La API Java SQL cuenta todo de 1, no desde cero, por lo que las columnas están numeradas 1 ... tamaño () y no 0 ... tamaño ()-1