Как преобразовать объект списка в bigdecimal в подготовленном выражении?
Я использую подготовленное заявление для массовой вставки записей. Я перебираю список, который содержит значения и их типы данных различаются. Одним из типов данных является BigDecimal, и когда я пытаюсь установить вызывающий подготовленный статус, он выдает исключение нулевого указателя.
Мой код
int count = 1;
for (int j = 0; j < list.size(); j++) {
if(list.get(j) instanceof Timestamp) {
ps.setTimestamp(count, (Timestamp) list.get(j));
} else if(list.get(j) instanceof java.lang.Character) {
ps.setString(count, String.valueOf(list.get(j)));
}
else if(list.get(j) instanceof java.math.BigDecimal) {
ps.setBigDecimal(count, (java.math.BigDecimal)list.get(j));
} else {
ps.setObject(count, list.get(j));
}
count++;
}
Я попытался 2 способа преобразования, приведение объекта и попытался создать новый объект типа BigDecimal
ps.setBigDecimal(count, new BigDecimal(list.get(j).toString));
оба не решают мою проблему. Выдает исключение нулевого указателя.
помощь приветствуется.
Спасибо
1 ответ
Вот решение, которое я нашел, оно кажется полезным для всех типов объектов и примитивных типов.
public static BigDecimal getBigDecimal( Object value ) {
BigDecimal ret = null;
if( value != null ) {
if( value instanceof BigDecimal ) {
ret = (BigDecimal) value;
} else if( value instanceof String ) {
ret = new BigDecimal( (String) value );
} else if( value instanceof BigInteger ) {
ret = new BigDecimal( (BigInteger) value );
} else if( value instanceof Number ) {
ret = new BigDecimal( ((Number)value).doubleValue() );
} else {
throw new ClassCastException("Not possible to coerce ["+value+"] from class "+value.getClass()+" into a BigDecimal.");
}
}
return ret;
}
вот ссылка: http://www.java2s.com/Code/Java/Data-Type/ConvertObjecttoBigDecimal.htm