Заполните отдельную таблицу без отношений в EF Core - PullRequest
1 голос
/ 27 июня 2019

Мне нужно добавить изображение и сохранить идентификатор изображения и идентификатор продукта в отдельной таблице productPicture.Вы не можете добавить изображение без существующего продукта.Как этого добиться?

Это мой код для добавления объекта в базу данных:

контроллер:

 [HttpPost]
    [Route("api/v1/catalog/products/pictures")]
    [ProducesResponseType((int)HttpStatusCode.Created)]
    [ProducesResponseType((int)HttpStatusCode.BadRequest)]
    public async Task<IActionResult> UploadPicture([FromForm]PictureViewModel pic)
    {
        try
        {
            var result = await _service.Add(pic);

            if (result.HasErrors)
            {
                return BadRequest(result.Errors);
            }

            return CreatedAtAction(nameof(GetById), result);
        }
        catch (Exception ex)
        {
            return BadRequest(ex.ToString());
        }
    }

сервис:

        public async Task<ServiceResultWithoutBaseEntity<Picture>> Add(PictureViewModel newItem)
    {
        var result = new ServiceResultWithoutBaseEntity<Picture>();
        result.Errors.AddRange(Validate(newItem));

        if (result.HasErrors)
            return result;

        var item = await newItem.MapToEntity(new Picture());

        _context.Pictures.Add(item);
        await _context.SaveChangesAsync();

        result.EntityResult = item;

        return result;
    }

помощник:

        public async static Task<Picture> MapToEntity(this PictureViewModel source, Picture entity)
    {
        if (source == null || entity == null)
            return null;

        if (source.FileForUpload != null || source.FileForUpload.Length != 0)
        {
            AzureBlobExtensions abe = new AzureBlobExtensions();
            string folderValue = string.Concat(entity.ID.ToString().ToLower(), "/", DateTime.Now.ToString("yyyyMMddHHmmss"), source.FileForUpload.FileName);
            var fileUrl = await abe.UploadFile(source.FileForUpload, folderValue, Path.GetExtension(source.FileForUpload.FileName), "Picture");
            entity.VirtualPath = fileUrl;
        }
        else
        {
            entity.VirtualPath = source.FileUrl;
        }

        entity.FileName = source.FileName;
        entity.SeoFilename = source.SeoFilename;
        entity.AltAttribute = source.AltAttribute;
        entity.TitleAtrribute = source.TitleAtrribute;
        entity.MimeType = source.MimeType;
        entity.IsNew = source.IsNew;

        return entity;
    }

таблица продуктов enter image description here

таблица изображений enter image description here

productPicture table

enter image description here

...