c# OData V4, EntityFramework 6, недостающие свойства - PullRequest
0 голосов
/ 03 марта 2020

Я пытаюсь перенести сервис, работающий нормально на oData V3 на V4. Я использую EntityFramework 6 для генерации кода из моей базы данных. Это сгенерированный код:

   namespace MyEntities
{
    using System;

    public partial class Civilite
    {

        public System.Guid pkCivilite { get; set; }
        public string civilite { get; set; }

    }
}

Это мой WebApiConfig:

public static class WebApiConfig
    {
        public static void Register(HttpConfiguration config)
        {
            // Web API configuration and services


            ODataModelBuilder builder = new ODataModelBuilder();

            builder.Namespace = "DataService";
            builder.ContainerName = "Container";

            var civiliteSet = builder.EntitySet<MyEntities.Civilite>("Civilites");
            civiliteSet.EntityType.HasKey(entity => entity.pkCivilite);

            config.MapODataServiceRoute(
            routeName: "odata",
            routePrefix: null,
            model: builder.GetEdmModel());

            config.EnsureInitialized();


        }

    }

Это мой контроллер:

public class CivilitesController : ODataController
    {

        MyEntities.Container db = new MyEntities.Container();

        private bool CiviliteExists(Guid key)
        {
            return db.CiviliteSet.Any(c => c.pkCivilite == key);
        }

        protected override void Dispose(bool disposing)
        {
            db.Dispose();
            base.Dispose(disposing);
        }

        [EnableQuery]
        public IQueryable<MyEntities.Civilite> Get()
        {

            return db.CiviliteSet;
        }

        [EnableQuery]
        public SingleResult<MyEntities.Civilite> Get([FromODataUri] Guid key)
        {
            IQueryable<MyEntities.Civilite> result = db.CiviliteSet.Where(p => p.pkCivilite == key);
            return SingleResult.Create(result);
        }

        public async Task<IHttpActionResult> Post(MyEntities.Civilite civilite)
        {
            if (!ModelState.IsValid)
            {
                return BadRequest(ModelState);
            }
            db.CiviliteSet.Add(civilite);
            await db.SaveChangesAsync();
            return Created(civilite);
        }

Но метаданные не возвращают свойство "цивилизация" типа string. Он только возвращает первичный ключ "pkCivilite" типа Guid.

<?xml version="1.0" encoding="ISO-8859-1"?>
<edmx:Edmx xmlns:edmx="http://docs.oasis-open.org/odata/ns/edmx" Version="4.0">
<edmx:DataServices>
<Schema xmlns="http://docs.oasis-open.org/odata/ns/edm" Namespace="DataService">
<EntityType Name="Civilite">
<Key>
<PropertyRef Name="pkCivilite"/>
</Key>
<Property Name="pkCivilite" Nullable="false" Type="Edm.Guid"/>
</EntityType>
<EntityContainer Name="Container">
<EntitySet Name="Civilites" EntityType="DataService.Civilite"/>
</EntityContainer>
</Schema>
</edmx:DataServices>
</edmx:Edmx>

Я попытался поместить [DataMember] в свойство "civilite" без успеха. Клиентский запрос работает. Я получаю все записи, но только с помощью свойства "pkCivilite". Что я делаю неправильно ? Спасибо за вашу помощь.

1 Ответ

0 голосов
/ 06 марта 2020

Моя ошибка заключалась в том, чтобы использовать ODataModelBuilder вместо ODataConventionModelBuilder.

Поэтому мне нужно было написать:

ODataModelBuilder builder = new ODataConventionModelBuilder();
...