While implementing AutoMapper in some existing code, I came across the need to map to a nullable property. Other business logic relied on this particular long being null instead of 0. The DTO has a property that contains a (long)Id, but the Entity contains the virtual property as well as a nullable long? of the Id. Anyway after fumbling through a few tries, I finally came upon the solution and wanted to share it here.

In the MapperProfile for the direction of DTO to Entity you have to do a null check, but the trick for me was having to explicitly cast to (long?)null.

CreateMap<ExampleDto, ExampleEntity>().ForMember(ee => ee.ExampleId, options => options.MapFrom(ed => ed.ExampleProperty != null ? ed.ExampleProperty.ExampleId : (long?)null)).NoVirtualMap();

Hope someone else finds this helpful, and finds it here.

    • zeroadam@programming.devOP
      link
      fedilink
      arrow-up
      1
      ·
      1 year ago

      I can certainly test this. My question would then be, will this result in actually mapping a null in the dto, or would the .ExampleProperty? just “be null” and cause the long property to instantiate to 0?

      • dbilitated
        link
        fedilink
        arrow-up
        1
        ·
        1 year ago

        i’m pretty sure it’ll be a long? - did you try it?

        • zeroadam@programming.devOP
          link
          fedilink
          arrow-up
          1
          ·
          edit-2
          1 year ago

          So… When I change…

          .ForMember(ee => ee.ExampleId, options => options.MapFrom(ed => ed.ExampleProperty != null ? ed.ExampleProperty.ExampleId : (long?)null))

          TO:

          .ForMember(ee => ee.ExampleId, options => options.MapFrom(ed => ed.ExampleProperty?.ExampleId))

          I am presented with: CS8072 - An expression tree lambda may not contain a null propagating operator.