ClassCastException 日期范围[]

问题描述

我尝试将 Daterange [] 转换为带有流的数组,但它给了我一个 ClassCastException 错误

Array pgArray = rs.getArray("periodo_carica");
 periodo_carica = (Daterange[]) pgArray.getArray();
 List<Daterange> periodo_carica2 = new ArrayList<Daterange>();
 periodo_carica2 =
                 Arrays.stream(periodo_carica)
                 .map(Daterange2::getRange)
                 .filter(d -> Daterange2.getRange(d) != null)
                 .collect(Collectors.toList());

输出

Connected to Postgresql server successfully!
Exception in thread "main" java.lang.classCastException: class [Ljava.lang.Object; cannot be cast to 
 class [Lorg.jfree.data.time.Daterange; ([Ljava.lang.Object; is in module java.base of loader 
'bootstrap'; [Lorg.jfree.data.time.Daterange; is in module [email protected] of loader 'app')

在我的 postgresql 数据库中,我有表,在 Eclipse 中的 java 中,我创建了相应的属性 Daterange[],您告诉我要设置为 OBJECT[] 但它是 Daterange[]

CREATE TABLE public.parlamentari
(
nome character varying(100) COLLATE pg_catalog."default" NOT NULL,partito character varying(100) COLLATE pg_catalog."default" NOT NULL,circoscrizione character varying(100) COLLATE pg_catalog."default" NOT NULL,data_nascita date,luogo character varying(100) COLLATE pg_catalog."default",titolo_studi character varying(100) COLLATE pg_catalog."default",mandati character varying(1000)[] COLLATE pg_catalog."default",commissioni character varying(100)[] COLLATE pg_catalog."default",periodo_carica daterange[],CONSTRAINT parlamentari_pkey PRIMARY KEY (nome,partito,circoscrizione),CONSTRAINT parlamentarinomekey UNIQUE (nome),CONSTRAINT parlamentaripartitonomekey UNIQUE (partito,nome)

 )

解决方法

更新

错误消息告诉我们从 getArray() 调用返回的值是 Object[],而不是 DateRange[]。当然,数组中的所有对象可能都是 DateRange 对象,但数组组件类型是 Object,而不是 DateRange,因此您必须进行两次转换。

Array pgArray = rs.getArray("periodo_carica");
Object[] periodo_carica = (Object[]) pgArray.getArray(); // cast to Object[]
List<DateRange> periodo_carica2 = new ArrayList<DateRange>();
periodo_carica2 =
                Arrays.stream(periodo_carica)
                .map(o -> (DateRange) o) // cast each element to DateRange
                .map(DateRange2::getRange)
                .filter(d -> DateRange2.getRange(d) != null)
                .collect(Collectors.toList());