avro架构问题-引发空指针异常,但数据有效

kuuvgm7e  于 2021-06-05  发布在  Kafka
关注(0)|答案(1)|浏览(428)

这是一个发送数据的例子,但由于某种原因,我得到了一个空指针异常,我试图去掉一些代码使其变小,但我想可能我需要保留很多模式来显示格式和嵌套字段。已编辑为只显示相关部分,因为不希望在网上公布我的架构

{
    "eventType": "XXX",
    "correlationId": "XXX",
    "timestamp": XXX,
    "policy": {
        "policyNumber": "XXX",
        "policyId": "XXX",
        "customerNumber": "XXX",
        ......(lots more fields like this)
        "insuredsAndDrivers": [{
            ......(lots more fields )
            "driver": {
                "relationshipToInsuredCd": "IN",
                "driverTypeCd": "P",
                "occupationCd": null,
                "driverLicenses": [{
                    "licenseTypeCd": null,
                    "licenseDate": null,
                    "licenseStateProvCd": null,
                    "licensePermitNumber": null
                }]
            }
        }, {
            ......(lots more fields like this)
            },
            "driver": null
        }],
        "vehicles": [{
            .....(lots of single fields here)
            "coverages": {
                .....(lots of single fields here)
            }
        }],
        "customer": {
            "extensionFields": {
                "nif": "XXX"
            },
            "individualDetails": {
                ......(lots more fields like this)
            },
            "phones": [{
                "phoneNumber": "1234567890"
            }],
            "addresses": [{
                ......(lots more fields like this)
            }]
        },
        "previous_policy": null
    }
}

这里是avro模式,抱歉,它很长

{
    "type": "record",
    "namespace": "my.namespace",
    "name": "MyEvent",
    "fields": [
                    ....lots of fields here
                    {
                        "name": "insuredsAndDrivers",
                        "default": [],
                        "type": {
                            "type": "array",
                            "items": {
                                "name": "InsuredsAndDrivers_Record",
                                "default": "",
                                "type": "record",
                                "fields": [
                                     ......(lots more fields here),
                                    {
                                        "name": "driver",
                                        "type": {
                                            "name": "Driver",
                                            "default": "",
                                            "type": "record",
                                            "fields": [{
                                                    "name": "relationshipToInsuredCd",
                                                    "type": ["string", "null"],
                                                    "default": ""
                                                },
                                                {
                                                    "name": "driverTypeCd",
                                                    "type": ["string", "null"],
                                                    "default": ""
                                                },
                                                {
                                                    "name": "occupationCd",
                                                    "type": ["string", "null"],
                                                    "default": ""
                                                },
                                                {
                                                    "name": "driverLicenses",
                                                    "default": [],
                                                    "type": {
                                                        "type": "array",
                                                        "items": {
                                                            "name": "DiverLicenses_Record",
                                                            "default": "",
                                                            "type": "record",
                                                            "fields": [{
                                                                    "name": "licenseTypeCd",
                                                                    "type": ["string", "null"],
                                                                    "default": ""
                                                                },
                                                                {
                                                                    "name": "licenseDate",
                                                                    "type": ["string", "null"],
                                                                    "default": ""
                                                                },
                                                                {
                                                                    "name": "licenseStateProvCd",
                                                                    "type": ["string", "null"],
                                                                    "default": ""
                                                                },
                                                                {
                                                                    "name": "licensePermitNumber",
                                                                    "type": ["string", "null"],
                                                                    "default": ""
                                                                }
                                                            ]
                                                        }
                                                    }
                                                }
                                            ]
                                        }
                                    }
                                ]
                            }
                        }
                    }

               ...rest of schema not relevant

我得到了错误 Caused by: java.lang.NullPointerException: null of com.lm.gde.eventing.avro.Driver of com.lm.gde.eventing.avro.InsuredsAndDrivers_Record of array of com.lm.gde.eventing.avro.Policy of com.lm.gde.eventing.avro.EnrichedPolicyEvent

q5iwbnjs

q5iwbnjs1#

数组“insuredsanddrivers”的第二个“insuredsanddrivers\u record”元素:

{
   "firstName": "XXX",
   "middleName": "Driver secondLastName",
   ...... (lots more fields here)
   "phones": [],
   "emails": [],
   "insured": {
       "primaryInsuredInd": "false"
   },
   "driver": null  <---- THIS
}

驱动程序字段为空,但架构将其定义为:

"name": "insuredsAndDrivers",
"default": [],
"type": {
    "type": "array",
    "items": { ... }
}

不可为空。您需要提供驱动程序或使数组的项类型成为具有null的并集。

相关问题