142 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			C#
		
	
	
	
		
		
			
		
	
	
			142 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			C#
		
	
	
	
|  | using System; | |||
|  | using System.Linq; | |||
|  | 
 | |||
|  | namespace BLL | |||
|  | { | |||
|  |     /// <summary> | |||
|  |     /// 考试记录 | |||
|  |     /// </summary> | |||
|  |     public static class TestRecordService | |||
|  |     { | |||
|  |         public static Model.SGGLDB db = Funs.DB; | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// 根据主键获取考试记录 | |||
|  |         /// </summary> | |||
|  |         /// <param name="testRecordId"></param> | |||
|  |         /// <returns></returns> | |||
|  |         public static Model.Training_TestRecord GetTestRecordById(string testRecordId) | |||
|  |         { | |||
|  |             return Funs.DB.Training_TestRecord.FirstOrDefault(e => e.TestRecordId == testRecordId); | |||
|  |         } | |||
|  |          | |||
|  |         /// <summary> | |||
|  |         /// 新增考生记录信息 | |||
|  |         /// </summary> | |||
|  |         /// <param name="Training"></param> | |||
|  |         public static void AddTestRecord(Model.Training_TestRecord testRecord) | |||
|  |         { | |||
|  |             Model.SGGLDB db = Funs.DB; | |||
|  |             Model.Training_TestRecord newTestRecord = new Model.Training_TestRecord | |||
|  |             { | |||
|  |                 TestRecordId = testRecord.TestRecordId, | |||
|  |                 ProjectId = testRecord.ProjectId, | |||
|  |                 TestPlanId = testRecord.TestPlanId, | |||
|  |                 TestManId = testRecord.TestManId, | |||
|  |                 TestType=testRecord.TestType, | |||
|  |             }; | |||
|  | 
 | |||
|  |             if (string.IsNullOrEmpty(newTestRecord.TestType)) | |||
|  |             { | |||
|  |                 var getTrainTypeName = (from x in db.Training_TestPlan | |||
|  |                                       join y in db.Training_Plan on x.PlanId equals y.PlanId | |||
|  |                                       join z in db.Base_TrainType on y.TrainTypeId equals z.TrainTypeId | |||
|  |                                       where x.TestPlanId == testRecord.TestPlanId | |||
|  |                                       select z).FirstOrDefault(); | |||
|  |                      | |||
|  |                 if (getTrainTypeName != null) | |||
|  |                 { | |||
|  |                     testRecord.TestType = getTrainTypeName.TrainTypeName; | |||
|  |                 } | |||
|  |             } | |||
|  | 
 | |||
|  |             db.Training_TestRecord.InsertOnSubmit(newTestRecord); | |||
|  |             db.SubmitChanges(); | |||
|  |         } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// 修改考试记录信息 | |||
|  |         /// </summary> | |||
|  |         /// <param name="Training"></param> | |||
|  |         public static void UpdateTestRecord(Model.Training_TestRecord testRecord) | |||
|  |         { | |||
|  |             Model.SGGLDB db = Funs.DB; | |||
|  |             Model.Training_TestRecord newTestRecord = db.Training_TestRecord.FirstOrDefault(e => e.TestRecordId == testRecord.TestRecordId); | |||
|  |             if (newTestRecord != null) | |||
|  |             { | |||
|  |                 newTestRecord.TestScores = testRecord.TestScores; | |||
|  |                 newTestRecord.TestEndTime = testRecord.TestEndTime; | |||
|  |                 newTestRecord.IsFiled = testRecord.IsFiled; | |||
|  |                 db.SubmitChanges(); | |||
|  |             } | |||
|  |         } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// 根据计划主键删除考试人员信息 | |||
|  |         /// </summary> | |||
|  |         /// <param name="planId"></param> | |||
|  |         public static void DeleteTestRecordByTestPlanId(string testPlanId) | |||
|  |         { | |||
|  |             var deleteRecords = from x in Funs.DB.Training_TestRecord where x.TestPlanId == testPlanId select x; | |||
|  |             if (deleteRecords.Count() > 0) | |||
|  |             { | |||
|  |                 foreach (var item in deleteRecords) | |||
|  |                 { | |||
|  |                     DeleteTestRecordByTestRecordId(item.TestRecordId); | |||
|  |                 } | |||
|  |             } | |||
|  |         } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// 根据考生主键删除考生信息 | |||
|  |         /// </summary> | |||
|  |         /// <param name="planId"></param> | |||
|  |         public static void DeleteTestRecordByTestRecordId(string testRecordId) | |||
|  |         { | |||
|  |             using (Model.SGGLDB db = new Model.SGGLDB(Funs.ConnString)) | |||
|  |             { | |||
|  |                 var testRecord = db.Training_TestRecord.FirstOrDefault(e => e.TestRecordId == testRecordId); | |||
|  |                 if (testRecord != null) | |||
|  |                 { | |||
|  |                     var testRecordItem = from x in db.Training_TestRecordItem where x.TestRecordId == testRecordId select x; | |||
|  |                     if (testRecordItem.Count() > 0) | |||
|  |                     { | |||
|  |                         db.Training_TestRecordItem.DeleteAllOnSubmit(testRecordItem); | |||
|  |                         db.SubmitChanges(); | |||
|  |                     } | |||
|  | 
 | |||
|  |                     db.Training_TestRecord.DeleteOnSubmit(testRecord); | |||
|  |                     db.SubmitChanges(); | |||
|  |                 } | |||
|  |             } | |||
|  |         } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// 更新没有结束时间且超时的考试记录 | |||
|  |         /// </summary> | |||
|  |         public static int UpdateTestEndTimeNull(string testRecordId) | |||
|  |         { | |||
|  |             int icount = 0; | |||
|  |             using (Model.SGGLDB db = new Model.SGGLDB(Funs.ConnString)) | |||
|  |             { | |||
|  |                 var testRecord = from x in db.Training_TestRecord | |||
|  |                                  where !x.TestEndTime.HasValue && x.TestStartTime.HasValue | |||
|  |                                  && x.TestStartTime.Value.AddMinutes(x.Duration) < DateTime.Now | |||
|  |                                  && x.TestRecordId == testRecordId | |||
|  |                                  select x; | |||
|  |                 if (testRecord.Count() > 0) | |||
|  |                 { | |||
|  |                     foreach (var item in testRecord) | |||
|  |                     { | |||
|  |                         item.TestEndTime = item.TestStartTime.Value.AddMinutes(item.Duration); | |||
|  |                         item.TestScores = db.Training_TestRecordItem.Where(x => x.TestRecordId == item.TestRecordId).Sum(x => x.SubjectScore) ?? 0; | |||
|  |                         db.SubmitChanges(); | |||
|  |                         icount++; | |||
|  |                     } | |||
|  |                 } | |||
|  |             } | |||
|  |             return icount; | |||
|  |         } | |||
|  |     } | |||
|  | } |