/// <summary> /// update bản ghi /// </summary> /// <param name="obj"></param> /// <returns></returns> public int Update(EXAMHALLSTUDENT_OBJ obj) { int ret = 0; EXAMHALLSTUDENT_BUS bus = new EXAMHALLSTUDENT_BUS(); var objTemp = bus.GetByID(new EXAMHALLSTUDENT_OBJ.BusinessObjectID(obj.CODE)); if (objTemp == null) { ret = -1; } else { // objTemp.EXAMFORMCODE = obj.EXAMFORMCODE; if (!string.IsNullOrWhiteSpace(obj.EXAMHALLCODE)) objTemp.EXAMHALLCODE = obj.EXAMHALLCODE; objTemp.LOCK = obj.LOCK; // = 0: thi bình thường, = 1: hủy kết quả thi objTemp.REALBEGINTIME = obj.REALBEGINTIME; objTemp.REALENDTIME = obj.REALENDTIME; objTemp.FINALENDTIME = obj.FINALENDTIME; objTemp.FINISHTIME = obj.FINISHTIME; objTemp.REPORTTIME = obj.REPORTTIME; objTemp.EDITTIME = DateTime.Now; obj.EDITUSER = _ses.loginCode; ret = bus.update(objTemp); } bus.CloseConnection(); return ret; }
/// <summary> /// xóa danh sách sinh viên trong đợt thi /// </summary> /// <param name="listCode"></param> /// <returns></returns> public JsonResult Delete(List<string> listCode) { var ret = 0; EXAMHALLSTUDENT_BUS bus = new EXAMHALLSTUDENT_BUS(); List<EXAMHALLSTUDENT_OBJ.BusinessObjectID> deletedata = new List<EXAMHALLSTUDENT_OBJ.BusinessObjectID>(); foreach (var code in listCode) { var item = bus.GetByID(new EXAMHALLSTUDENT_OBJ.BusinessObjectID(code)); if (item != null) { deletedata.Add(item._ID); } } if (deletedata.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 bus.BeginTransaction(); ret = bus.DeletetMultiItems(deletedata); 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() bus.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 bus.CommitTransaction(); } } bus.CloseConnection(); return Json(new { ret }, JsonRequestBehavior.AllowGet); }
///// <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)); }