Реализовал модели бд курса, симтпома и симптомаДиагноза
This commit is contained in:
parent
a0ecb7b222
commit
5805b378b4
@ -72,32 +72,25 @@ namespace PolyclinicDatabaseImplement.Models
|
|||||||
|
|
||||||
public void UpdateDiagnoses(PolyclinicDatabase context, CourseBindingModel model)
|
public void UpdateDiagnoses(PolyclinicDatabase context, CourseBindingModel model)
|
||||||
{
|
{
|
||||||
//var courseDiagnoses = context.CourseDiagnoses.Where(rec => rec.CourseId == model.Id).ToList();
|
var courseDiagnoses = context.CourseDiagnoses.Where(rec => rec.CourseId == model.Id).ToList();
|
||||||
//if (courseDiagnoses != null && courseDiagnoses.Count > 0)
|
if (courseDiagnoses != null && courseDiagnoses.Count > 0)
|
||||||
//{
|
{
|
||||||
// // удалили те, которых нет в модели
|
// удалили те, которых нет в модели
|
||||||
// context.CourseDiagnoses.RemoveRange(courseDiagnoses.Where(rec => !model.CourseDiagnoses.ContainsKey(rec.DiagnoseId)));
|
context.CourseDiagnoses.RemoveRange(courseDiagnoses
|
||||||
// context.SaveChanges();
|
.Where(rec => !model.CourseDiagnoses.ContainsKey(rec.DiagnoseId)));
|
||||||
// // обновили количество у существующих записей
|
context.SaveChanges();
|
||||||
// foreach (var updateDiagnose in courseDiagnoses)
|
}
|
||||||
// {
|
var course = context.Courses.First(x => x.Id == Id);
|
||||||
// updateDiagnose.Count = model.CourseDiagnoses[updateDiagnose.DiagnoseId].Item2;
|
foreach (var pc in model.CourseDiagnoses)
|
||||||
// model.CourseDiagnoses.Remove(updateDiagnose.DiagnoseId);
|
{
|
||||||
// }
|
context.CourseDiagnoses.Add(new CourseDiagnose
|
||||||
// context.SaveChanges();
|
{
|
||||||
//}
|
Course = course,
|
||||||
//var course = context.Courses.First(x => x.Id == Id);
|
Diagnose = context.Diagnoses.First(x => x.Id == pc.Key),
|
||||||
//foreach (var pc in model.CourseDiagnoses)
|
});
|
||||||
//{
|
context.SaveChanges();
|
||||||
// context.CourseDiagnoses.Add(new CourseDiagnose
|
}
|
||||||
// {
|
_courseDiagnoses = null;
|
||||||
// Course = course,
|
|
||||||
// Diagnose = context.Diagnoses.First(x => x.Id == pc.Key),
|
|
||||||
// Count = pc.Value.Item2
|
|
||||||
// });
|
|
||||||
// context.SaveChanges();
|
|
||||||
//}
|
|
||||||
//_courseDiagnoses = null;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,12 +1,87 @@
|
|||||||
using PolyclinicDataModels.Models;
|
using PolyclinicContracts.BindingModels;
|
||||||
|
using PolyclinicContracts.ViewModels;
|
||||||
|
using PolyclinicDataModels.Models;
|
||||||
|
using SecuritySystemDatabaseImplement;
|
||||||
|
using System.ComponentModel.DataAnnotations;
|
||||||
|
using System.ComponentModel.DataAnnotations.Schema;
|
||||||
|
|
||||||
namespace PolyclinicDatabaseImplement.Models
|
namespace PolyclinicDatabaseImplement.Models
|
||||||
{
|
{
|
||||||
public class Symptom : ISymptomModel
|
public class Symptom : ISymptomModel
|
||||||
{
|
{
|
||||||
public string Name => throw new NotImplementedException();
|
[Required]
|
||||||
public string Comment => throw new NotImplementedException();
|
public string Name { get; set; } = string.Empty;
|
||||||
public Dictionary<int, IDiagnoseModel> SymptomDiagnoses => throw new NotImplementedException();
|
[Required]
|
||||||
public int Id => throw new NotImplementedException();
|
public string Comment { get; set; } = string.Empty;
|
||||||
|
[ForeignKey("SymptomId")]
|
||||||
|
public virtual List<SymptomDiagnose> Diagnoses { get; set; } = new();
|
||||||
|
private Dictionary<int, IDiagnoseModel>? _symptomDiagnoses = null;
|
||||||
|
[NotMapped]
|
||||||
|
public Dictionary<int, IDiagnoseModel> SymptomDiagnoses
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
if (_symptomDiagnoses == null)
|
||||||
|
{
|
||||||
|
_symptomDiagnoses = Diagnoses.ToDictionary(
|
||||||
|
symptomDiagnose => symptomDiagnose.DiagnoseId,
|
||||||
|
symptomDiagnose => symptomDiagnose.Diagnose as IDiagnoseModel
|
||||||
|
);
|
||||||
|
}
|
||||||
|
return _symptomDiagnoses;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public int Id { get; set; }
|
||||||
|
|
||||||
|
public static Symptom Create(PolyclinicDatabase context, SymptomBindingModel model)
|
||||||
|
{
|
||||||
|
return new Symptom()
|
||||||
|
{
|
||||||
|
Id = model.Id,
|
||||||
|
Name = model.Name,
|
||||||
|
Comment = model.Comment,
|
||||||
|
Diagnoses = model.SymptomDiagnoses.Select(symptomDiagnose => new SymptomDiagnose
|
||||||
|
{
|
||||||
|
Diagnose = context.Diagnoses.First(diagnose => diagnose.Id == symptomDiagnose.Key)
|
||||||
|
}).ToList()
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
public void Update(SymptomBindingModel model)
|
||||||
|
{
|
||||||
|
Comment = model.Comment;
|
||||||
|
Name = model.Name;
|
||||||
|
}
|
||||||
|
|
||||||
|
public SymptomViewModel GetViewModel => new()
|
||||||
|
{
|
||||||
|
Id = Id,
|
||||||
|
Comment = Comment,
|
||||||
|
Name = Name,
|
||||||
|
SymptomDiagnoses = SymptomDiagnoses
|
||||||
|
};
|
||||||
|
|
||||||
|
public void UpdateDiagnoses(PolyclinicDatabase context, SymptomBindingModel model)
|
||||||
|
{
|
||||||
|
var symptomDiagnoses = context.SymptomDiagnoses.Where(rec => rec.SymptomId == model.Id).ToList();
|
||||||
|
if (symptomDiagnoses != null && symptomDiagnoses.Count > 0)
|
||||||
|
{
|
||||||
|
// удалили те, которых нет в модели
|
||||||
|
context.SymptomDiagnoses.RemoveRange(symptomDiagnoses
|
||||||
|
.Where(rec => !model.SymptomDiagnoses.ContainsKey(rec.DiagnoseId)));
|
||||||
|
context.SaveChanges();
|
||||||
|
}
|
||||||
|
var course = context.Symptomes.First(x => x.Id == Id);
|
||||||
|
foreach (var pc in model.SymptomDiagnoses)
|
||||||
|
{
|
||||||
|
context.SymptomDiagnoses.Add(new SymptomDiagnose
|
||||||
|
{
|
||||||
|
Symptom = course,
|
||||||
|
Diagnose = context.Diagnoses.First(x => x.Id == pc.Key),
|
||||||
|
});
|
||||||
|
context.SaveChanges();
|
||||||
|
}
|
||||||
|
_symptomDiagnoses = null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,15 @@
|
|||||||
namespace PolyclinicDatabaseImplement.Models
|
using System.ComponentModel.DataAnnotations;
|
||||||
|
|
||||||
|
namespace PolyclinicDatabaseImplement.Models
|
||||||
{
|
{
|
||||||
public class SymptomDiagnose
|
public class SymptomDiagnose
|
||||||
{
|
{
|
||||||
|
public int Id { get; set; }
|
||||||
|
[Required]
|
||||||
|
public int SymptomId { get; set; }
|
||||||
|
[Required]
|
||||||
|
public int DiagnoseId { get; set; }
|
||||||
|
public virtual Symptom Symptom { get; set; } = new();
|
||||||
|
public virtual Diagnose Diagnose { get; set; } = new();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user