///// <summary> ///// chấm điểm cho 1 sinh viên ///// </summary> ///// <param name="examhallstudent"></param> ///// <returns></returns> public JsonResult GetMark(string examhallstudentcode) { // kiểm tra xem còn bản ghi examhallstudentcode này trên server ko EXAMHALLSTUDENT_BUS examhallstudentBus = new EXAMHALLSTUDENT_BUS(); var examhallstudent = examhallstudentBus.GetByID(new EXAMHALLSTUDENT_OBJ.BusinessObjectID(examhallstudentcode)); var ret = (examhallstudent == null) ? -1 : 0; if (ret >= 0) { // lấy kết quả thi của sinh viên này EXAMRESULT_BUS examresultBus = new EXAMRESULT_BUS(); var examresult = examresultBus.getAllBy2("EXAMFORMDETAILCODE", new fieldpara("EXAMHALLSTUDENTCODE", examhallstudentcode, 0)); if (examresult != null && examresult.Count > 0) { // lấy danh sách câu hỏi và câu trả lời của sinh viên, trừ các dạng câu hỏi: điền vào đoạn trống tự điền từ, viết lại câu, viết đoạn văn, nghe nói, viết DataSet ds = new DataSet(); ret = examresultBus.getExamresult(ref ds, "examresult", examresult[0].EXAMHALLSTUDENTCODE); List <EXAMRESULT_OBJ> liResult1 = new List <EXAMRESULT_OBJ>(); // danh sách câu hỏi kiểu trắc nghiệm List <EXAMRESULT_OBJ> liResultFg = new List <EXAMRESULT_OBJ>(); // lấy danh sách câu hỏi dạng điền vào đoạn trống tự gõ từ List <EXAMRESULT_OBJ> liResultRw = new List <EXAMRESULT_OBJ>(); // lấy danh sách câu hỏi dạng viết lại câu if (ret >= 0) { foreach (DataRow r in ds.Tables["examresult"].Rows) { var objtemp = new EXAMRESULT_OBJ { EXAMFORMDETAILCODE = com.string4Row(r, "examformdetailcode", ""), QUESTIONCODE = com.string4Row(r, "questioncode", ""), ANSWERCODE = com.string4Row(r, "answercode", ""), ANSWERTEXT = com.string4Row(r, "answertext", ""), QUESTIONGROUPCODE = com.string4Row(r, "questiongroupcode", "") }; string questiontype = com.string4Row(r, "questiontype", ""); // nếu thuộc 6 dạng này thì add vào result1 if (questiontype.Equals("MC") || questiontype.Equals("FI") || questiontype.Equals("CO") || questiontype.Equals("LA") || questiontype.Equals("PA") || questiontype.Equals("MS")) { liResult1.Add(objtemp); } // nếu là dạng điền vào đoạn trống thì add vào resulf FG if (questiontype.Equals("FG")) { liResultFg.Add(objtemp); } // nếu là dạng điền vào đoạn trống thì add vào resulfRW if (questiontype.Equals("RW")) { liResultRw.Add(objtemp); } } } // lấy danh sách câu hỏi và câu trả lời trong đề thi của sinh viên var examformcode = examresult[0].EXAMFORMCODE; ds = new DataSet(); ret = examresultBus.getExamform(ref ds, "examform", examformcode); List <dynamic> liQuestion = new List <dynamic>(); if (ret >= 0) { foreach (DataRow r in ds.Tables["examform"].Rows) { dynamic question = new ExpandoObject(); question.QUESTIONCODE = com.string4Row(r, "code", ""); // mã câu hỏi question.TRUEANSWER = com.string4Row(r, "trueanswer", ""); // đáp án đúng // question.MARK = com.string4Row(r, "mark", ""); // số điểm cho câu hỏi này question.MARK = float.Parse(com.string4Row(r, "mark", ""), CultureInfo.InvariantCulture.NumberFormat); question.CONTENT = com.string4Row(r, "content", ""); // nội dung câu hỏi, sử dụng trong trường hợp điền vào đoạn trống tự gõ từ, viết lại câu liQuestion.Add(question); } } // so sánh dạng trắc nghiệm, nếu đúng thì update lại điểm List <EXAMRESULT_OBJ> dataUpdate = new List <EXAMRESULT_OBJ>(); List <fieldpara> lipa = new List <fieldpara>(); foreach (var item in liResult1) { foreach (var item2 in liQuestion) { if (item.QUESTIONCODE == item2.QUESTIONCODE && item.ANSWERCODE == item2.TRUEANSWER) { item.EXAMHALLSTUDENTCODE = examhallstudentcode; item.EXAMFORMCODE = examformcode; lipa.Clear(); lipa.Add(new fieldpara("EXAMHALLSTUDENTCODE", examhallstudentcode, 0)); lipa.Add(new fieldpara("EXAMFORMDETAILCODE", item.EXAMFORMDETAILCODE, 0)); lipa.Add(new fieldpara("QUESTIONCODE", item.QUESTIONCODE, 0)); lipa.Add(new fieldpara("QUESTIONGROUPCODE", item.QUESTIONGROUPCODE, 0)); var obj = examresultBus.GetByKey(lipa.ToArray()); if (obj != null) { obj.MARK = 1; if (item2.MARK > 0) { obj.MARK = item2.MARK; } dataUpdate.Add(obj); } else { ret = -1; } } } } // so sánh dạng điền vào chỗ trống tự gõ từ foreach (var item in liResultFg) { foreach (var item2 in liQuestion) { if (item.QUESTIONCODE == item2.QUESTIONCODE) { // so sánh câu trả lời của sinh viên có khớp với đáp án hay không string answer = item.ANSWERTEXT; // Câu trả lời của sinh viên string trueanswer = item2.CONTENT; // Nội dung câu trả lời answer = answer.Trim(); // loại bỏ các kí tự html trueanswer = StripHtml(trueanswer).Trim(); if (String.Compare(answer, trueanswer, StringComparison.OrdinalIgnoreCase) == 0) { item.EXAMHALLSTUDENTCODE = examhallstudentcode; item.EXAMFORMCODE = examformcode; lipa.Clear(); lipa.Add(new fieldpara("EXAMHALLSTUDENTCODE", examhallstudentcode, 0)); lipa.Add(new fieldpara("EXAMFORMDETAILCODE", item.EXAMFORMDETAILCODE, 0)); lipa.Add(new fieldpara("QUESTIONCODE", item.QUESTIONCODE, 0)); lipa.Add(new fieldpara("QUESTIONGROUPCODE", item.QUESTIONGROUPCODE, 0)); var obj = examresultBus.GetByKey(lipa.ToArray()); if (obj != null) { obj.MARK = 1; if (item2.MARK > 0) { obj.MARK = item2.MARK; } dataUpdate.Add(obj); } else { ret = -1; } } } } } // so sánh dạng viết lại câu foreach (var item in liResultRw) { foreach (var item2 in liQuestion) { if (item.QUESTIONCODE == item2.QUESTIONCODE) { // so sánh câu trả lời của sinh viên có khớp với đáp án hay không string answer = item.ANSWERTEXT; // Câu trả lời của sinh viên string trueanswer = item2.CONTENT; // Nội dung câu trả lời answer = answer.Trim(); // loại bỏ các kí tự html trueanswer = StripHtml(trueanswer).Trim(); // regex về dạng chuẩn answer = RegexAnswer(answer); if (String.Compare(answer, trueanswer, StringComparison.OrdinalIgnoreCase) == 0) { item.EXAMHALLSTUDENTCODE = examhallstudentcode; item.EXAMFORMCODE = examformcode; lipa.Clear(); lipa.Add(new fieldpara("EXAMHALLSTUDENTCODE", examhallstudentcode, 0)); lipa.Add(new fieldpara("EXAMFORMDETAILCODE", item.EXAMFORMDETAILCODE, 0)); lipa.Add(new fieldpara("QUESTIONCODE", item.QUESTIONCODE, 0)); lipa.Add(new fieldpara("QUESTIONGROUPCODE", item.QUESTIONGROUPCODE, 0)); var obj = examresultBus.GetByKey(lipa.ToArray()); if (obj != null) { obj.MARK = 1; if (item2.MARK > 0) { obj.MARK = item2.MARK; } dataUpdate.Add(obj); } else { ret = -1; } } } } } if (dataUpdate.Count > 0) { //mặc định khi vào danh sách này là xóa thành công nên ret= 1; //duyệt toàn bộ danh sách bản ghi để xóa examresultBus.BeginTransaction(); ret = examresultBus.UpdateMultiItems(dataUpdate); if (ret < 0) { //Trong trường hợp nhiều thao tác, có một thao tác không thành công, //hàm này được gọi để quay lại trạng thái trước khi thực hiện (bắt đầu từ khi gọi BeginTransaction() examresultBus.RollbackTransaction(); } else { //Sau khi thao tác dữ liệu thành công, hàm này được gọi để thực hiện ghi vào cơ sở dữ liệu examresultBus.CommitTransaction(); } } return(Json(new { ret }, JsonRequestBehavior.AllowGet)); } } examhallstudentBus.CloseConnection(); return(Json(new { }, JsonRequestBehavior.AllowGet)); }
/// <summary> /// Lấy ra chi tiết của một bài thi dựa vào mã sinh viên trong bảng điểm lớp môn học và mã học kì /// </summary> /// <param name="markcode">mã sinh viên trong lớp môn học</param> /// <param name="examtimecode">mã học kì </param> /// <returns></returns> public JsonResult GetDetailExam(string markcode, string examtimecode) { if (string.IsNullOrEmpty(markcode)) { markcode = "1708310001"; } int ret = 0; int numberQuestion = 0; MARK_BUS markbus = new MARK_BUS(); MARK_OBJ objmark = markbus.GetByID(new MARK_OBJ.BusinessObjectID(markcode));//markbus.GetByKey(new fieldpar("STUDENTCODE", _ses.loginCode, 0),new fieldpara("COURSECODE", courseCode, 0)); markbus.CloseConnection(); if (objmark == null) { ret = -7; } EXAMHALLSTUDENT_OBJ obj = new EXAMHALLSTUDENT_OBJ(); if (ret >= 0) { EXAMHALLSTUDENT_BUS bus = new EXAMHALLSTUDENT_BUS(); if (objmark != null) { obj = bus.GetByKey(new fieldpara("MARKCODE", objmark.CODE, 0), new fieldpara("examtimecode", examtimecode)); } bus.CloseConnection(); } //Lấy được một lần thi if (obj == null) { ret = -1; } EXAMFORM_BUS busExamform = new EXAMFORM_BUS(); EXAMFORM_OBJ objExamform = null; //Lấy đề thi if (ret >= 0) { if (obj != null) { objExamform = busExamform.GetByID((new EXAMFORM_OBJ.BusinessObjectID(obj.EXAMFORMCODE))); } busExamform.CloseConnection(); if (objExamform == null) { ret = -2; } } //Danh sachs cau truc EXAMFORMDETAIL_BUS busExamformdetail = new EXAMFORMDETAIL_BUS(); List <EXAMFORMDETAIL_OBJ> liExamformdetail = new List <EXAMFORMDETAIL_OBJ>(); if (ret >= 0) { if (objExamform != null) { liExamformdetail = busExamformdetail.getAllBy2("THEORDER", new fieldpara("EXAMFORMCODE", objExamform.CODE)); } busExamformdetail.CloseConnection(); if (liExamformdetail == null) { ret = -3; } } List <fieldpara> lipa = new List <fieldpara>(); List <jointable> lijoin = new List <jointable>(); //Lay danh sach cac nhom cau hoi QUESTIONGROUP_BUS busQuestiongroup = new QUESTIONGROUP_BUS(); List <QUESTIONGROUP_OBJ> liQuestiongroup = new List <QUESTIONGROUP_OBJ>(); if (ret >= 0) { if (objExamform != null) { lijoin.Add(new jointable(typeof(EXAMFORMDETAIL_OBJ), "CODE", "QUESTIONGROUPCODE", new fieldpara("EXAMFORMCODE", objExamform.CODE))); } liQuestiongroup = busQuestiongroup.getAllBy2("CODE", lipa, lijoin); if (liQuestiongroup == null) { ret = -4; } busQuestiongroup.CloseConnection(); } //Lay danh sach cau hoi QUESTION_BUS busQuestion = new QUESTION_BUS(); List <QUESTION_OBJ> listQuestionreturn = new List <QUESTION_OBJ>(); if (ret >= 0) { lijoin.Clear(); if (objExamform != null) { lijoin.Add(new jointable(typeof(EXAMFORMDETAIL_OBJ), "QUESTIONGROUPCODE", "QUESTIONGROUPCODE", new fieldpara("examformcode", objExamform.CODE))); } var liQuestion = busQuestion.getAllBy2("CODE", lipa, lijoin); if (liQuestion == null) { ret = -5; } else { foreach (var objQuestion in liQuestion) { QUESTION_OBJ objTemp = new QUESTION_OBJ(); objTemp.CODE = objQuestion.CODE; objTemp.ANSWERCODE = null; objTemp.CONTENT = objQuestion.CONTENT; objTemp.QUESTIONGROUPCODE = objQuestion.QUESTIONGROUPCODE; objTemp._QUESTIONGROUPCODE = objQuestion._QUESTIONGROUPCODE; objTemp._ID = objQuestion._ID; listQuestionreturn.Add(objTemp); } numberQuestion = liQuestion.Count; } busQuestion.CloseConnection(); } //Lay danh danh cac dap an ANSWER_BUS busAnswer = new ANSWER_BUS(); List <ANSWER_OBJ> liAnswer = new List <ANSWER_OBJ>(); if (ret >= 0) { lijoin.Clear(); if (objExamform != null) { lijoin.Add((new jointable(typeof(EXAMFORMDETAIL_OBJ), "QUESTIONGROUPCODE", "QUESTIONGROUPCODE", new fieldpara("examformcode", objExamform.CODE)))); } liAnswer = busAnswer.getAllBy2("CODE", lipa, lijoin); if (liAnswer == null) { ret = -6; } busAnswer.CloseConnection(); } //get list exam result in case student lost the internet EXAMRESULT_BUS busExamresult = new EXAMRESULT_BUS(); List <EXAMRESULT_OBJ> liExamresult = new List <EXAMRESULT_OBJ>(); if (ret >= 0) { if (obj != null) { liExamresult = busExamresult.getAllBy2(new fieldpara("examhallstudentcode", obj.CODE)); } busExamresult.CloseConnection(); } var jsonResult = Json(new { numberQuestion, //so luong cau hoi ObjexamHallstudent = obj, //examhallstudent code ObjexamForm = objExamform, //examform liExamformDetail = liExamformdetail, //Danh sách examdetail liQuestiongroup, //danh sach nhom cau hoi li_question = listQuestionreturn, //danh sach cac cau hoi li_answer = liAnswer, //danh sach tat ca cac cau tra loi liExamresult, //danh sach tat ca cac dap an da tra loi cu sinh vien ret //ok }, JsonRequestBehavior.AllowGet); jsonResult.MaxJsonLength = int.MaxValue; return(jsonResult); }
/// <summary> /// logic: truyền vào coursecode và examtimecode /// từ coursecode và examtimecode -> tìm được examhallstudent tương ứng -> lấy ra được examformcode chính là đề thi mà sinh viên đó làm /// lấy ra danh sách các nhóm câu hỏi của đề thi đấy (dữ liệu trong bảng examformdetail) /// lấy danh sách các câu hỏi /// </summary> /// <param name="coursecode">mã lớp môn học</param> /// <param name="examtimecode"></param> /// <returns></returns> public JsonResult ShowExamResult(string coursecode, string examtimecode) { if (string.IsNullOrEmpty(coursecode)) { coursecode = "1708310001"; } if (string.IsNullOrEmpty(examtimecode)) { examtimecode = "1712250004"; } var ret = 0; string studentcode = ""; List <QUESTION_OBJ> liQuestion = null; List <ANSWER_OBJ> liAnswer = null; List <EXAMRESULT_OBJ> liExamresult = null; EXAMFORM_OBJ objExamform = null; List <EXAMFORMDETAIL_OBJ> liExamformdetail = null; List <QUESTIONGROUP_OBJ> liQuestiongroup = null; int numberQuestion = 0; // số câu hỏi EXAMHALLSTUDENT_OBJ examhallstudentObj = new EXAMHALLSTUDENT_OBJ(); if (_ses.loginType.Equals("STUDENT")) { studentcode = _ses.loginCode; } else { ret = -1; } if (ret >= 0) { List <fieldpara> lipa = new List <fieldpara>(); // get mark MARK_BUS markBus = new MARK_BUS(); lipa.Add(new fieldpara("STUDENTCODE", studentcode, 0)); lipa.Add(new fieldpara("COURSECODE", coursecode, 0)); lipa.Add(new fieldpara("UNIVERSITYCODE", _ses.gUNIVERSITYCODE, 0)); var mark = markBus.GetByKey(lipa.ToArray()); markBus.CloseConnection(); if (mark != null) { EXAMHALLSTUDENT_BUS bus = new EXAMHALLSTUDENT_BUS(); examhallstudentObj = bus.GetByKey(new fieldpara("MARKCODE", mark.CODE, 0), new fieldpara("EXAMTIMECODE", examtimecode)); bus.CloseConnection(); if (examhallstudentObj != null) { // lấy đề thi EXAMFORM_BUS busExamform = new EXAMFORM_BUS(); objExamform = busExamform.GetByID((new EXAMFORM_OBJ.BusinessObjectID(examhallstudentObj.EXAMFORMCODE))); busExamform.CloseConnection(); if (objExamform != null) { // lấy danh sách chi tiết đề thi EXAMFORMDETAIL_BUS busExamformdetail = new EXAMFORMDETAIL_BUS(); liExamformdetail = busExamformdetail.getAllBy2("THEORDER", new fieldpara("EXAMFORMCODE", objExamform.CODE)); busExamformdetail.CloseConnection(); if (liExamformdetail != null) { lipa = new List <fieldpara>(); List <jointable> lijoin = new List <jointable>(); //Lay danh sach cac nhom cau hoi QUESTIONGROUP_BUS busQuestiongroup = new QUESTIONGROUP_BUS(); lijoin.Add(new jointable(typeof(EXAMFORMDETAIL_OBJ), "CODE", "QUESTIONGROUPCODE", new fieldpara("EXAMFORMCODE", objExamform.CODE))); liQuestiongroup = busQuestiongroup.getAllBy2("CODE", lipa, lijoin); busQuestiongroup.CloseConnection(); if (liQuestiongroup != null) { //Lay danh sach cau hoi QUESTION_BUS busQuestion = new QUESTION_BUS(); lijoin.Clear(); lijoin.Add(new jointable(typeof(EXAMFORMDETAIL_OBJ), "QUESTIONGROUPCODE", "QUESTIONGROUPCODE", new fieldpara("examformcode", objExamform.CODE))); liQuestion = busQuestion.getAllBy2("CODE", lipa, lijoin); numberQuestion = liQuestion.Count; busQuestion.CloseConnection(); // lấy danh sách các câu trả lời lijoin.Clear(); ANSWER_BUS busAnswer = new ANSWER_BUS(); lijoin.Add(new jointable(typeof(EXAMFORMDETAIL_OBJ), "QUESTIONGROUPCODE", "QUESTIONGROUPCODE", new fieldpara("examformcode", objExamform.CODE))); liAnswer = busAnswer.getAllBy2("CODE", lipa, lijoin); busAnswer.CloseConnection(); // lấy danh sách kết quả thi của sinh vên đó EXAMRESULT_BUS busExamresult = new EXAMRESULT_BUS(); liExamresult = busExamresult.getAllBy2(new fieldpara("examhallstudentcode", examhallstudentObj.CODE)); busExamresult.CloseConnection(); if (liAnswer == null || liExamresult == null) { ret = -7; } } else { ret = -6; } } else { ret = -5; } } else { ret = -4; } } else { ret = -3; } } else { ret = -2; } } else { ret = -1; } var jsonResult = Json(new { numberQuestion, //so luong cau hoi ObjexamHallstudent = examhallstudentObj, //examhallstudent code ObjexamForm = objExamform, //examform liExamformDetail = liExamformdetail, //Danh sách examdetail liQuestiongroup, li_question = liQuestion, li_answer = liAnswer, li_examresult = liExamresult,//danh sách đáp án ret }, JsonRequestBehavior.AllowGet); jsonResult.MaxJsonLength = int.MaxValue; return(jsonResult); }
/// <summary> /// lấy danh sách kết quả thi trong 1 course của 1 sinh viên /// </summary> /// <param name="markcode"></param> /// <param name="coursecode">mã lớp môn học</param> /// <returns></returns> public JsonResult GetResult(string markcode, string coursecode) { // List <Exam> liExam = new List <Exam>(); // lấy danh sách các lần thi của sinh viên trong 1 lớp học EXAMHALLSTUDENT_BUS bus = new EXAMHALLSTUDENT_BUS(); List <fieldpara> lipa = new List <fieldpara> { new fieldpara("MARKCODE", markcode, 0), new fieldpara("COURSECODE", coursecode, 0), new fieldpara("UNIVERSITYCODE", _ses.gUNIVERSITYCODE, 0) }; var liExamHallStudent = bus.getAllBy2("CODE", lipa.ToArray()); // lấy điểm cụ thể của từng đợt thi if (liExamHallStudent != null) { EXAMRESULT_BUS examresultBus = new EXAMRESULT_BUS(); foreach (var item in liExamHallStudent) { Exam exam = new Exam { ExamHallStudentCode = item.CODE }; // lấy tên đợt thi string examTimeName = item._EXAMTIMECODE.NAME; exam.Name = examTimeName; // danh sách các câu hỏi và điểm trong bài thi List <Question> liQuestion = new List <Question>(); var liExamReSult = examresultBus.getAllBy2("QUESTIONCODE", new fieldpara("EXAMHALLSTUDENTCODE", item.CODE, 0)); for (int i = 0; i < liExamReSult.Count - 1; i++) { double totalMark = 0; var questiongroupcode = liExamReSult[i].QUESTIONGROUPCODE; string questionName = liExamReSult[i]._QUESTIONGROUPCODE.NAME; if (!string.IsNullOrEmpty(questiongroupcode)) { totalMark += liExamReSult[i].MARK; liExamReSult[i].QUESTIONGROUPCODE = ""; for (int j = i + 1; j < liExamReSult.Count; j++) { if (liExamReSult[j].QUESTIONGROUPCODE == questiongroupcode) { totalMark += liExamReSult[j].MARK; liExamReSult[j].QUESTIONGROUPCODE = ""; } } } if (!string.IsNullOrEmpty(questiongroupcode)) { Question question = new Question { QuestionGroupCode = questiongroupcode, Mark = totalMark, Name = questionName }; liQuestion.Add(question); } } exam.ListQuestion = liQuestion; liExam.Add(exam); examresultBus.CloseConnection(); } } bus.CloseConnection(); return(Json(new { data = liExam }, JsonRequestBehavior.AllowGet)); }
public JsonResult UpdateExamResult(List <QuestionAnswer> listobj, EXAMFORM_OBJ examform, List <EXAMFORMDETAIL_OBJ> listexamformdetail, string examhallstudentcode) { //bài thi của sinh viên sẽ đưa lên gồm có : mã câu hỏi,mã câu trả lời, nội dung câu trả lời // examformcode: mã đề thi , examformdetailcode: mã phần thi // answerfile: link file muốn lưu trên server cho bài thi nói ////list answer, QuestionAnswer {MaCauHoi,MaXTL} var ret = 0; int add = 0; QUESTIONTYPE_BUS busQuestiontype = new QUESTIONTYPE_BUS(); List <QUESTIONTYPE_OBJ> liQuestiontype = busQuestiontype.getAllBy2(); busQuestiontype.CloseConnection(); // list question answer // List<QuestionAnswer> listStudentAnswer = JsonConvert.DeserializeObject<List<QuestionAnswer>>(listobj); List <QuestionAnswer> listStudentAnswer = listobj; if (listStudentAnswer.Count <= 0) { ret = -1; } //list EXAMFORMDETAIL_OBJ // List<EXAMFORMDETAIL_OBJ> listEXamDetail = JsonConvert.DeserializeObject<List<EXAMFORMDETAIL_OBJ>>(listexamformdetail); List <EXAMFORMDETAIL_OBJ> listEXamDetail = listexamformdetail; if (listEXamDetail.Count <= 0) { ret = -2; } // list examform // string exCode = examformcode; // EXAMFORM_OBJ objExForm = JsonConvert.DeserializeObject<EXAMFORM_OBJ>(exCode); EXAMFORM_OBJ objExForm = examform; //examhallstudentcode string exHallcode = examhallstudentcode; //object examresult EXAMRESULT_BUS bus = new EXAMRESULT_BUS(); QUESTION_BUS busQuestion = new QUESTION_BUS(); // QUESTIONGROUP_BUS busQGroup = new QUESTIONGROUP_BUS(); // duyet trong list examformdetail foreach (var item in listEXamDetail) { //lay danh sach question theo tung questiongroup trong examformdetail List <QUESTION_OBJ> liQuestion = busQuestion.getAllBy2("CODE", new fieldpara("QUESTIONGROUPCODE", item.QUESTIONGROUPCODE)); //duyet trong list question foreach (var question in liQuestion) { //duyet trong danh sach cau tra loi cua sinh vien de dua ra la cau hoi nay la cap nhat hay them moi foreach (var answer in listStudentAnswer) { //kiem tra su ton tai cua cau hoi if (answer.MaCauHoi == question.CODE) { //question group to determinecasse writing var objTemp = bus.GetByID(new EXAMRESULT_OBJ.BusinessObjectID(exHallcode, item.CODE, question.CODE)); //chua co thi tuc la them moi if (objTemp == null) { add = 1; objTemp = new EXAMRESULT_OBJ(); } objTemp.EXAMHALLSTUDENTCODE = exHallcode; objTemp.EXAMFORMDETAILCODE = item.CODE; objTemp.EXAMFORMCODE = objExForm.CODE; objTemp.QUESTIONCODE = question.CODE; objTemp.QUESTIONGROUPCODE = item.QUESTIONGROUPCODE; switch (getCodeview(liQuestiontype, item.TESTSTRUCTDETAILCODE)) // thực chất là item._QUESTIONGROUPCODE.QUESTIONTYPECODE nhưng do ko gửi được _QUESTIONGROUPCODE lên, do đó gán tạm TESTSTRUCTDETAILCODE = (item._QUESTIONGROUPCODE.QUESTIONTYPECODE) { //multichoice //1 case "MC": //"1707130001": objTemp.ANSWERCODE = answer.MaCauTL; objTemp.ANSWERTEXT = ""; break; //single choice case //2 case "MS": objTemp.ANSWERCODE = answer.MaCauTL; objTemp.ANSWERTEXT = ""; break; //case CO, true,false,not given //3 case "CO": objTemp.ANSWERCODE = answer.MaCauTL; objTemp.ANSWERTEXT = ""; break; //write //4 case "WR": // "1707130007": objTemp.ANSWERCODE = ""; objTemp.ANSWERTEXT = answer.MaCauTL; break; //rewrite //5 case "RW": // "1707130004": objTemp.ANSWERCODE = ""; objTemp.ANSWERTEXT = answer.MaCauTL; break; //NGHE NOI //6 case "LA": // "1708300007": //LA objTemp.ANSWERFILE = GetName(answer.MaCauTL); break; //trường hợp điền từ vào ô trống //7 case "FG": objTemp.ANSWERCODE = ""; objTemp.ANSWERTEXT = answer.MaCauTL; break; //TRUONG HOP KEO THA VAO O TRONG //8 case "FI": objTemp.ANSWERCODE = answer.MaCauTL; objTemp.ANSWERTEXT = ""; break; // Keo tha vao o trong //9 case "FF": objTemp.ANSWERCODE = answer.MaCauTL; objTemp.ANSWERTEXT = ""; break; //cau hoi ghep doi //10 case "PA": objTemp.ANSWERCODE = answer.MaCauTL; objTemp.ANSWERTEXT = ""; break; //dạng câu hỏi sắp xếp lại câu //11 case "RA": objTemp.ANSWERTEXT = answer.MaCauTL; objTemp.ANSWERCODE = ""; break; default: objTemp.ANSWERCODE = ""; objTemp.ANSWERTEXT = ""; break; } objTemp.LOCK = objExForm.LOCK; objTemp.LOCKDATE = DateTime.Now; objTemp.MARK = 0; if (add > 0) { ret = bus.insert(objTemp); } else { objTemp._ID.QUESTIONCODE = question.CODE; objTemp._ID.EXAMFORMDETAILCODE = item.CODE; objTemp._ID.EXAMHALLSTUDENTCODE = exHallcode; ret = bus.update(objTemp); } } } } } if (ret >= 0) { _ses.tSOURCEPATHSESSION?.Clear(); _ses.tDESTINATIONPATHSESSION?.Clear(); } return(Json(new { ret }, JsonRequestBehavior.AllowGet)); }