Немного поправил слой моделей базы данных
This commit is contained in:
parent
b7138a2b01
commit
72ff843aff
@ -13,7 +13,7 @@ namespace ComputerShopContracts.BindingModels
|
||||
|
||||
public int UserId { get; set; }
|
||||
|
||||
public int AssemblyId { get; set; }
|
||||
public int? AssemblyId { get; set; }
|
||||
|
||||
public DateTime DateMake { get; set; } = DateTime.Now;
|
||||
|
||||
|
@ -22,7 +22,7 @@ namespace ComputerShopContracts.ViewModels
|
||||
public string UserLogin { get; set; } = string.Empty;
|
||||
|
||||
//id сборки
|
||||
public int AssemblyId { get; set; }
|
||||
public int? AssemblyId { get; set; }
|
||||
|
||||
|
||||
//!!!МБ НАДО БУДЕТ ПРИВЯЗЫВАТЬ НАЗВАНИЕ СБОРКИ И Т.Д. ДЛЯ ОТЧЁТОВ
|
||||
|
@ -17,7 +17,7 @@ namespace ComputerShopDataModels.Models
|
||||
/// <summary>
|
||||
/// ID сборки
|
||||
/// </summary>
|
||||
int AssemblyId { get; }
|
||||
int? AssemblyId { get; }
|
||||
|
||||
Dictionary<int, IOrderModel> RequestOrders { get; }
|
||||
|
||||
|
@ -5,6 +5,7 @@ using ComputerShopDataModels.Models;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.ComponentModel.DataAnnotations;
|
||||
using System.ComponentModel.DataAnnotations.Schema;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
@ -16,7 +17,6 @@ namespace ComputerShopDatabaseImplement.Models
|
||||
{
|
||||
public int Id { get; set; }
|
||||
|
||||
//!!!ТУТ МБ СДЕЛАТЬ КАК FOREIGN KEY
|
||||
[Required]
|
||||
public int UserId { get; private set; }
|
||||
|
||||
@ -32,13 +32,20 @@ namespace ComputerShopDatabaseImplement.Models
|
||||
//!!!мб не нужен
|
||||
public virtual User User { get; set; }
|
||||
|
||||
//!!!ПРОВЕРМТЬ, ЧТО ПАРВИЛЬНЫЕ ВНЕШНИЕ КЛЮЧИ
|
||||
|
||||
[ForeignKey("OrderId")]
|
||||
public virtual List<RequestOrder> RequestOrders { get; set; } = new();
|
||||
|
||||
[ForeignKey("OrderId")]
|
||||
public virtual List<ShipmentOrder> ShipmentOrders { get; set; } = new();
|
||||
|
||||
public static Order? Create(OrderBindingModel model)
|
||||
{
|
||||
if (model == null)
|
||||
{
|
||||
return null;
|
||||
}
|
||||
using var context = new ComputerShopDatabase();
|
||||
return new Order()
|
||||
{
|
||||
Id = model.Id,
|
||||
@ -56,7 +63,7 @@ namespace ComputerShopDatabaseImplement.Models
|
||||
return;
|
||||
}
|
||||
using var context = new ComputerShopDatabase();
|
||||
//!!!МБ НАДО БУДЕТ ОБНОВЛЯТЬ ПОЛЬЗОВАТЕЛЯ, НО ОН ПО СУТИ НЕ ДОЛЖЕН ОБНОВЯЛТЬСЯ ПОСЛЕ СОЗДАНИЯ
|
||||
//!!!МБ НАДО БУДЕТ ОБНОВЛЯТЬ ПОЛЬЗОВАТЕЛЯ, НО ОН ПО СУТИ НЕ ДОЛЖЕН ОБНОВЛЯТЬСЯ ПОСЛЕ СОЗДАНИЯ
|
||||
Status = model.Status;
|
||||
context.SaveChanges();
|
||||
}
|
||||
|
@ -12,6 +12,7 @@ using System.Threading.Tasks;
|
||||
namespace ComputerShopDatabaseImplement.Models
|
||||
{
|
||||
//!!!ДОБАВИТЬ МЕТОД ПО ПРИВЯЗКЕ СБОРКИ
|
||||
//!!!МБ У Id сделать private set у ВСЕХ МОИХ МОДЕЛЕЙ
|
||||
public class Request : IRequestModel
|
||||
{
|
||||
public int Id { get; set; }
|
||||
@ -20,9 +21,11 @@ namespace ComputerShopDatabaseImplement.Models
|
||||
|
||||
public virtual User User { get; set; }
|
||||
|
||||
public int AssemblyId { get; set; }
|
||||
public int? AssemblyId { get; set; }
|
||||
|
||||
[Required]
|
||||
public DateTime DateMake { get; set; }
|
||||
|
||||
[Required]
|
||||
public string ClientFIO { get; set; } = string.Empty;
|
||||
|
||||
@ -36,14 +39,17 @@ namespace ComputerShopDatabaseImplement.Models
|
||||
if (_requestOrders == null)
|
||||
{
|
||||
//!!!ТУТ ПРОПИСАТЬ ЛОГИКУ (НЕ ЗНАЮ ПОКА, КАК)
|
||||
|
||||
if (_requestOrders == null)
|
||||
{
|
||||
_requestOrders = Orders.ToDictionary(x => x.OrderId, x => (x.Order as IOrderModel));
|
||||
}
|
||||
|
||||
}
|
||||
return _requestOrders;
|
||||
}
|
||||
}
|
||||
|
||||
[ForeignKey("OrderId")]
|
||||
[ForeignKey("RequestId")]
|
||||
public virtual List<RequestOrder> Orders { get; set; } = new();
|
||||
|
||||
public static Request Create(ComputerShopDatabase context, RequestBindingModel model)
|
||||
|
@ -16,7 +16,6 @@ namespace ComputerShopDatabaseImplement.Models
|
||||
{
|
||||
public int Id { get; set; }
|
||||
|
||||
//!!!ТУТ МБ СДЕЛАТЬ КАК FOREIGN KEY
|
||||
[Required]
|
||||
public int UserId { get; private set; }
|
||||
|
||||
@ -42,17 +41,16 @@ namespace ComputerShopDatabaseImplement.Models
|
||||
if (_shipmentOrders == null)
|
||||
{
|
||||
//!!!ТУТ ПРОПИСАТЬ ЛОГИКУ (НЕ ЗНАЮ ПОКА, КАК)
|
||||
|
||||
|
||||
_shipmentOrders = Orders.ToDictionary(x => x.OrderId, x => (x.Order as IOrderModel));
|
||||
}
|
||||
return _shipmentOrders;
|
||||
}
|
||||
}
|
||||
//!!!ПРОВЕРИТЬ, ЧТО ТУТ ПРАВИЛЬНО СДЕЛАНО (ЧТО НАЗВАНИЕ ПРАВИЛЬНОЕ У ВНЕШ. КЛЮЧА, ЧТО ПРАВИЛЬНЫЙ ТИП в <>)
|
||||
[ForeignKey("OrderId")]
|
||||
[ForeignKey("ShipmentId")]
|
||||
public virtual List<ShipmentOrder> Orders { get; set; } = new();
|
||||
|
||||
//!!!МБ ТУТ НАДО БУДЕТ ПРИСВАИВАТЬ ORDERS (но вряд ли, потому что по заданию заказы привязываются отдельно)
|
||||
|
||||
//!!!ПРОВЕРИТЬ, ЧТО ПРАВИЛЬНО ПРИСВАИВАЮ ЗНАЧЕНИЕ СПИСКУ ЗАКАЗОВ
|
||||
public static Shipment Create(ComputerShopDatabase context, ShipmentBindingModel model)
|
||||
{
|
||||
@ -96,7 +94,6 @@ namespace ComputerShopDatabaseImplement.Models
|
||||
//удаление тех заказов, которых нет в модели
|
||||
if (shipmentOrders != null && shipmentOrders.Count > 0)
|
||||
{
|
||||
|
||||
//!!!ТУТ МБ НЕ x.OrderId, а x.ShipmentId, но не факт (вряд ли)
|
||||
context.ShipmentOrders.RemoveRange(shipmentOrders.Where(x => !model.ShipmentOrders.ContainsKey(x.OrderId)));
|
||||
context.SaveChanges();
|
||||
|
Loading…
Reference in New Issue
Block a user