コード例 #1
0
 public IActionResult Add([FromBody] DutySchedule model)
 {
     try
     {
         if (model == null)
         {
             return(BadRequest());
         }
         using (var db = new AllInOneContext.AllInOneContext())
         {
             db.DutySchedule.Add(model);
             db.SaveChanges();
             return(Created("", "OK"));
         }
     }
     catch (DbUpdateException dbEx)
     {
         return(BadRequest(new ApplicationException {
             ErrorCode = "DBUpdate", ErrorMessage = "数据保存异常:" + dbEx.Message
         }));
     }
     catch (System.Exception ex)
     {
         return(BadRequest(new ApplicationException {
             ErrorCode = "Unknown", ErrorMessage = ex.Message
         }));
     }
 }
コード例 #2
0
        public IActionResult Get(Guid id)
        {
            try
            {
                using (var db = new AllInOneContext.AllInOneContext())
                {
                    DutySchedule data = db.DutySchedule
                                        .Include(t => t.Lister)
                                        .Include(t => t.Organization)
                                        .Include(t => t.Schedule).ThenInclude(t => t.ScheduleCycle).ThenInclude(t => t.DayPeriods).ThenInclude(t => t.TimePeriods)
                                        .Include(t => t.Schedule).ThenInclude(t => t.ScheduleType)
                                        .Include(t => t.DutyScheduleDetails).ThenInclude(t => t.CadreSchedule)
                                        .Include(t => t.DutyScheduleDetails).ThenInclude(t => t.OfficerSchedule)
                                        .Include(t => t.DutyScheduleDetails).ThenInclude(t => t.NetWatcherSchedule).ThenInclude(t => t.Leader)
                                        .Include(t => t.DutyScheduleDetails).ThenInclude(t => t.NetWatcherSchedule).ThenInclude(t => t.Deputy)
                                        .Include(t => t.DutyScheduleDetails).ThenInclude(t => t.NetWatcherSchedule).ThenInclude(t => t.CheckTimePeriod)
                                        .FirstOrDefault(p => p.DutyScheduleId.Equals(id));
                    if (data == null)
                    {
                        return(NoContent());
                    }

                    return(new ObjectResult(data));
                }
            }
            catch (Exception ex)
            {
                return(BadRequest(new ApplicationException {
                    ErrorCode = "Unknown", ErrorMessage = ex.Message
                }));
            }
        }
コード例 #3
0
        public IActionResult DeleteDutySchedule(Guid id)
        {
            try
            {
                using (var db = new AllInOneContext.AllInOneContext())
                {
                    using (var tran = db.Database.BeginTransaction())
                    {
                        DutySchedule dutySchedule = db.DutySchedule
                                                    .Include(t => t.Lister)
                                                    .Include(t => t.Organization)
                                                    .Include(t => t.Schedule).ThenInclude(t => t.ScheduleCycle).ThenInclude(t => t.DayPeriods).ThenInclude(t => t.TimePeriods)
                                                    .Include(t => t.Schedule).ThenInclude(t => t.ScheduleType)
                                                    .Include(t => t.DutyScheduleDetails).ThenInclude(t => t.CadreSchedule)
                                                    .Include(t => t.DutyScheduleDetails).ThenInclude(t => t.OfficerSchedule)
                                                    .Include(t => t.DutyScheduleDetails).ThenInclude(t => t.NetWatcherSchedule).ThenInclude(t => t.Leader)
                                                    .Include(t => t.DutyScheduleDetails).ThenInclude(t => t.NetWatcherSchedule).ThenInclude(t => t.Deputy)
                                                    .Include(t => t.DutyScheduleDetails).ThenInclude(t => t.NetWatcherSchedule).ThenInclude(t => t.CheckTimePeriod)
                                                    .FirstOrDefault(p => p.DutyScheduleId.Equals(id));
                        if (dutySchedule == null)
                        {
                            return(NoContent());
                        }
                        //
                        RemoveLinkage(db, dutySchedule);
                        //
                        db.DutySchedule.Remove(dutySchedule);
                        db.SaveChanges();

                        tran.Commit();
                        return(new NoContentResult());
                    }
                }
            }
            catch (System.Exception ex)
            {
                return(BadRequest(new ApplicationException {
                    ErrorCode = "Unknown", ErrorMessage = ex.Message
                }));
            }
        }
コード例 #4
0
        private static void RemoveLinkage(AllInOneContext.AllInOneContext db, DutySchedule dutySchedule)
        {
            foreach (DutyScheduleDetail dsd in dutySchedule.DutyScheduleDetails)
            {
                if (dsd.NetWatcherSchedule != null)
                {
                    List <DutyCheckSchedule> delList = new List <DutyCheckSchedule>();
                    foreach (DutyCheckSchedule rp in dsd.NetWatcherSchedule)
                    {
                        DutyCheckSchedule del = db.Set <DutyCheckSchedule>()
                                                .FirstOrDefault(p => p.DutyCheckScheduleId.Equals(rp.DutyCheckScheduleId));
                        if (del != null)
                        {
                            delList.Add(del);
                        }
                    }
                    db.Set <DutyCheckSchedule>().RemoveRange(delList);
                    db.SaveChanges();
                }
            }


            if (dutySchedule.DutyScheduleDetails != null)
            {
                List <DutyScheduleDetail> delList = new List <DutyScheduleDetail>();
                foreach (DutyScheduleDetail detail in dutySchedule.DutyScheduleDetails)
                {
                    DutyScheduleDetail del = db.Set <DutyScheduleDetail>().FirstOrDefault(p => p.DutyScheduleDetailId.Equals(detail.DutyScheduleDetailId));
                    if (del != null)
                    {
                        delList.Add(del);
                    }
                }
                db.Set <DutyScheduleDetail>().RemoveRange(delList);
                db.SaveChanges();
            }
        }
コード例 #5
0
        public IActionResult Update([FromBody] DutySchedule model)
        {
            try
            {
                if (model == null)
                {
                    return(BadRequest());
                }
                using (var db = new AllInOneContext.AllInOneContext())
                {
                    using (var tran = db.Database.BeginTransaction())
                    {
                        DutySchedule dutySchedule = db.DutySchedule
                                                    .Include(t => t.Lister)
                                                    .Include(t => t.Organization)
                                                    .Include(t => t.Schedule).ThenInclude(t => t.ScheduleCycle).ThenInclude(t => t.DayPeriods).ThenInclude(t => t.TimePeriods)
                                                    .Include(t => t.Schedule).ThenInclude(t => t.ScheduleType)
                                                    .Include(t => t.DutyScheduleDetails).ThenInclude(t => t.CadreSchedule)
                                                    .Include(t => t.DutyScheduleDetails).ThenInclude(t => t.OfficerSchedule)
                                                    .Include(t => t.DutyScheduleDetails).ThenInclude(t => t.NetWatcherSchedule).ThenInclude(t => t.Leader)
                                                    .Include(t => t.DutyScheduleDetails).ThenInclude(t => t.NetWatcherSchedule).ThenInclude(t => t.Deputy)
                                                    .Include(t => t.DutyScheduleDetails).ThenInclude(t => t.NetWatcherSchedule).ThenInclude(t => t.CheckTimePeriod)
                                                    .FirstOrDefault(p => p.DutyScheduleId.Equals(model.DutyScheduleId));
                        if (dutySchedule == null)
                        {
                            return(BadRequest());
                        }
                        //转换普通数据
                        dutySchedule.EndDate        = model.EndDate;
                        dutySchedule.ListerId       = model.ListerId;
                        dutySchedule.OrganizationId = model.OrganizationId;
                        dutySchedule.StartDate      = model.StartDate;
                        dutySchedule.TabulationTime = model.TabulationTime;
                        dutySchedule.ScheduleId     = model.ScheduleId;
                        //
                        RemoveLinkage(db, dutySchedule);
                        //
                        dutySchedule.DutyScheduleDetails = model.DutyScheduleDetails;
                        //
                        db.DutySchedule.Update(dutySchedule);
                        db.SaveChanges();

                        tran.Commit();

                        return(new NoContentResult());
                    }
                }
            }
            catch (DbUpdateException dbEx)
            {
                return(BadRequest(new ApplicationException {
                    ErrorCode = "DBUpdate", ErrorMessage = "数据保存异常:" + dbEx.Message
                }));
            }
            catch (System.Exception ex)
            {
                return(BadRequest(new ApplicationException {
                    ErrorCode = "Unknown", ErrorMessage = ex.Message
                }));
            }
        }