周口郸城医院 DanChengCallCenter_API

QuestionnaireController.cs 81KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762
  1. using CallCenter.Utility;
  2. using CallCenterApi.DB;
  3. using CallCenterApi.Interface.Controllers.Base;
  4. using CallCenterApi.Interface.Models.Dto;
  5. using CallCenterApi.Interface.Models.Filter;
  6. using CallCenterApi.Interface.Models.Input;
  7. using System;
  8. using System.Collections.Generic;
  9. using System.Data;
  10. using System.Linq;
  11. using System.Text;
  12. using System.Web;
  13. using System.Web.Mvc;
  14. namespace CallCenterApi.Interface.Controllers.Question
  15. {
  16. public class QuestionnaireController : BaseController
  17. {
  18. private readonly BLL.T_Ask_QuestionCategory qCategoryBLL = new BLL.T_Ask_QuestionCategory();
  19. private readonly BLL.T_Ask_Question questionBLL = new BLL.T_Ask_Question();
  20. private readonly BLL.T_Ask_QuestionItems questionItemBLL = new BLL.T_Ask_QuestionItems();
  21. private readonly BLL.T_Ask_PagerInfo pagerInfoBLL = new BLL.T_Ask_PagerInfo();
  22. private readonly BLL.T_Ask_PagerItems pagerInfoItemsBLL = new BLL.T_Ask_PagerItems();
  23. //患者随访完成中 填写的问卷答案
  24. public ActionResult GetQuestionAnswerDetail(int id)
  25. {
  26. DataTable dt = DbHelperSQL.Query($" SELECT F_QID, F_CusTelID,(SELECT F_Title FROM T_Ask_PagerInfo WHERE F_PagerId = (SELECT F_PagerId FROM T_Ask_PagerItems WHERE F_QuestionId = F_QID)) as Name,F_Answer,F_Title FROM T_Call_OutAnswers a LEFT JOIN T_Ask_Question b ON a.F_QID = b.F_QuestionId WHERE a.F_CusTelID =" + id + "").Tables[0];
  27. // SELECT F_QID, F_CusTelID,
  28. //(SELECT F_Title FROM T_Ask_PagerInfo WHERE F_PagerId = (SELECT F_PagerId FROM T_Ask_PagerItems WHERE F_QuestionId = F_QID)),
  29. //F_Answer,F_Title FROM T_Call_OutAnswers a LEFT JOIN T_Ask_Question b ON a.F_QID = b.F_QuestionId
  30. //--ORDER BY F_OptOn DESC
  31. //WHERE F_CusTelID = '10633384'
  32. // DataTable dt = DbHelperSQL.Query($" SELECT * FROM T_Call_OutAnswers a LEFT JOIN T_Ask_Question b ON a.F_QID = b.F_QuestionId WHERE a.F_CusTelID =" + id + "").Tables[0];
  33. List<returnmodel> list = new List<returnmodel>();
  34. foreach (DataRow item in dt.Rows)
  35. {
  36. returnmodel rmodel = new returnmodel();
  37. rmodel.QuestionTitle = item["F_Title"]?.ToString();
  38. rmodel.Answer = item["F_Answer"]?.ToString();
  39. rmodel.Name = item["Name"]?.ToString();
  40. list.Add(rmodel);
  41. }
  42. return Success("获取问卷信息成功", list);
  43. }
  44. #region 问卷设置 - 试题问卷
  45. /// <summary>
  46. /// 问卷设置 - 试题问卷
  47. /// </summary>
  48. /// <param name="filter"></param>
  49. /// <returns></returns>
  50. public ActionResult GetPagerInfoList(FilterPagerInfo filter)
  51. {
  52. string sql = "";
  53. if (!string.IsNullOrWhiteSpace(filter.Key))
  54. {
  55. sql += $" and (F_Title like '%{ filter.Key.Trim()}%' or F_Remark like '%{ filter.Key.Trim()}%') ";
  56. }
  57. var recordCount = 0;
  58. var dt = BLL.PagerBLL.GetListPager(
  59. "T_Ask_PagerInfo",
  60. "F_PagerId",
  61. "*",
  62. " and F_DeleteFlag=0 " + sql,
  63. "ORDER BY F_PagerId desc",
  64. filter.PageSize,
  65. filter.PageIndex,
  66. true,
  67. out recordCount);
  68. var obj = new
  69. {
  70. rows = dt,
  71. total = recordCount
  72. };
  73. return Content(obj.ToJson());
  74. }
  75. public ActionResult GetPagerInfoModel(int pid)
  76. {
  77. var model = pagerInfoBLL.GetModel(pid);
  78. return Success("获取问卷成功", model);
  79. }
  80. public ActionResult CreateOrUpdatePager(Pagerinfo input)
  81. {
  82. var model = new Model.T_Ask_PagerInfo();
  83. if (input.Id <= 0)
  84. {
  85. model.F_Title = input.Title;
  86. model.F_StartText = input.StartText;
  87. model.F_EndText = input.EndText;
  88. model.F_Remark = input.Remark;
  89. model.F_Times = input.Times;
  90. model.F_DeleteFlag = 0;
  91. model.F_CreateOn = DateTime.Now;
  92. model.F_CreateBy = CurrentUser.UserData.F_UserId;
  93. if (pagerInfoBLL.Add(model) > 0)
  94. return Success("添加问卷成功" + ",操作人:" + CurrentUser.UserData.F_UserCode);
  95. return Error("添加问卷失败" + ",操作人:" + CurrentUser.UserData.F_UserCode);
  96. }
  97. model = pagerInfoBLL.GetModel(input.Id);
  98. model.F_Title = input.Title;
  99. model.F_StartText = input.StartText;
  100. model.F_EndText = input.EndText;
  101. model.F_Remark = input.Remark;
  102. model.F_Times = input.Times;
  103. model.F_DeleteFlag = 0;
  104. model.F_ModifyBy = CurrentUser.UserData.F_UserId;
  105. model.F_ModifyOn = DateTime.Now;
  106. if (pagerInfoBLL.Update(model))
  107. return Success("修改问卷成功" + ",操作人:" + CurrentUser.UserData.F_UserCode);
  108. return Error("修改问卷失败" + ",操作人:" + CurrentUser.UserData.F_UserCode);
  109. }
  110. /// <summary>
  111. /// 选择试题 - 修改 - 选择试题(左侧)
  112. /// </summary>
  113. /// <returns></returns>
  114. public ActionResult GetQuestionNotItemsList(FilterQuestion filter)
  115. {
  116. StringBuilder sb = new StringBuilder();
  117. if (filter.CategoryId > 0)
  118. {
  119. sb.Append(" and F_CategoryId=" + filter.CategoryId);
  120. }
  121. if (filter.SelectType > 0)
  122. {
  123. sb.Append(" and F_Type=" + filter.SelectType);
  124. }
  125. if (filter.PagerId > 0)
  126. {
  127. sb.Append(" and F_QuestionId not in (SELECT [F_QuestionId] FROM [T_Ask_PagerItems] where [F_PagerId]=" + filter.PagerId + ") ");
  128. }
  129. if (!string.IsNullOrWhiteSpace(filter.Key))
  130. {
  131. sb.Append(" and (F_Title like '%" + filter.Key + "%' or F_Content like '%" + filter.Key + "%') ");
  132. }
  133. var recordCount = 0;
  134. var dt = BLL.PagerBLL.GetListPager(
  135. "vw_Ask_Question",
  136. "F_QuestionId",
  137. "*",
  138. " and F_DeleteFlag=0 " + sb.ToString(),
  139. "ORDER BY F_QuestionId desc",
  140. filter.PageSize,
  141. filter.PageIndex,
  142. true,
  143. out recordCount);
  144. var quesitemlist = questionItemBLL.GetModelList("");
  145. for (int i = 0; i < dt.Rows.Count; i++)
  146. {
  147. var items = "";
  148. string qid = dt.Rows[i]["F_QuestionId"].ToString();
  149. var quesitem = quesitemlist.Where(qi => qi.F_QuestionId == int.Parse(qid));
  150. if (quesitem.Count() > 0)
  151. {
  152. foreach (var item in quesitem)
  153. {
  154. items += ";" + item.F_ItemName;
  155. }
  156. }
  157. dt.Rows[i]["F_Content"] = items.Trim(';');
  158. }
  159. var obj = new
  160. {
  161. rows = dt,
  162. total = recordCount
  163. };
  164. return Content(obj.ToJson());
  165. }
  166. /// <summary>
  167. /// 选择试题 - 修改 - 选择试题(右侧)
  168. /// </summary>
  169. /// <returns></returns>
  170. public ActionResult GetQuestionPageList(FilterQuestion filter)
  171. {
  172. StringBuilder sb = new StringBuilder();
  173. if (filter.PagerId > 0)
  174. {
  175. sb.Append(" and F_PagerId=" + filter.PagerId);
  176. }
  177. var recordCount = 0;
  178. var dt = BLL.PagerBLL.GetListPager(
  179. "vw_Ask_PagerQuestion",
  180. "F_ItemId",
  181. "*",
  182. " and F_DeleteFlag=0 " + sb.ToString(),
  183. "ORDER BY F_Sort desc",
  184. filter.PageSize,
  185. filter.PageIndex,
  186. true,
  187. out recordCount);
  188. var quesitemlist = questionItemBLL.GetModelList("");
  189. for (int i = 0; i < dt.Rows.Count; i++)
  190. {
  191. var items = "";
  192. string qid = dt.Rows[i]["F_QuestionId"].ToString();
  193. var quesitem = quesitemlist.Where(qi => qi.F_QuestionId == int.Parse(qid));
  194. if (quesitem.Count() > 0)
  195. {
  196. foreach (var item in quesitem)
  197. {
  198. items += ";" + item.F_ItemName;
  199. }
  200. }
  201. dt.Rows[i]["F_Content"] = items.Trim(';');
  202. }
  203. var obj = new
  204. {
  205. rows = dt,
  206. total = recordCount
  207. };
  208. return Content(obj.ToJson());
  209. }
  210. /// <summary>
  211. /// 选择试题 - 修改 - 批量选入(左侧 -> 右侧)
  212. /// </summary>
  213. /// <returns></returns>
  214. public ActionResult AddPagerItems(string[] ids, string pid, string sort = "0")
  215. {
  216. //string[] arrid = ids.Split(',');
  217. if (ids.Count() > 0)
  218. {
  219. int intsort = 0;
  220. intsort = Convert.ToInt32(sort) + 1;
  221. int cc = 0;
  222. foreach (string squestionid in ids)
  223. {
  224. Model.T_Ask_PagerItems model = new Model.T_Ask_PagerItems();
  225. int pagerid = 0;
  226. int questionid = 0;
  227. pagerid = Convert.ToInt32(pid);
  228. questionid = Convert.ToInt32(squestionid);
  229. model.F_PagerId = pagerid;
  230. model.F_QuestionId = questionid;
  231. model.F_Sort = intsort;
  232. intsort++;
  233. if (pagerInfoItemsBLL.Add(model) > 0)
  234. {
  235. cc++;
  236. }
  237. }
  238. if (cc == ids.Length)
  239. {
  240. return Success("选入试题成功" + ",操作人:" + CurrentUser.UserData.F_UserCode);
  241. }
  242. }
  243. return Error("选入试题失败" + ",操作人:" + CurrentUser.UserData.F_UserCode);
  244. }
  245. /// <summary>
  246. /// 选择试题 - 修改 - 批量选出(右侧 -> 左侧)
  247. /// </summary>
  248. /// <returns></returns>
  249. public ActionResult DelPagerItems(string[] ids)
  250. {
  251. //string[] arrid = ids.Split(',');
  252. if (ids.Length > 0)
  253. {
  254. int cc = 0;
  255. foreach (string itemid in ids)
  256. {
  257. if (pagerInfoItemsBLL.Delete(Convert.ToInt32(itemid)))
  258. {
  259. cc++;
  260. }
  261. }
  262. if (cc == ids.Length)
  263. {
  264. return Success("选出试题成功" + ",操作人:" + CurrentUser.UserData.F_UserCode);
  265. }
  266. }
  267. return Error("选出试题失败" + ",操作人:" + CurrentUser.UserData.F_UserCode);
  268. }
  269. /// <summary>
  270. /// 删除试题问卷(删除两表信息)
  271. /// </summary>
  272. /// <param name="id"></param>
  273. /// <returns></returns>
  274. public ActionResult DeletePagerInfo(int id = 0)
  275. {
  276. if (pagerInfoBLL.Delete(id))
  277. {
  278. pagerInfoItemsBLL.DeleteByPagerId(id);
  279. return Success("删除试题问卷成功" + ",操作人:" + CurrentUser.UserData.F_UserCode);
  280. }
  281. else
  282. {
  283. return Error("删除试题问卷失败" + ",操作人:" + CurrentUser.UserData.F_UserCode);
  284. }
  285. }
  286. //获取问卷列表
  287. public ActionResult GetPagerList()
  288. {
  289. ActionResult res = NoToken("未知错误,请重新登录");
  290. if (Request.IsAuthenticated)
  291. {
  292. List<Model.T_Ask_PagerInfo> pagerList = pagerInfoBLL.GetModelList(" F_DeleteFlag=0 order by F_PagerId desc ");
  293. if (pagerList.Count > 0)
  294. res = Success("问卷列表加载成功", pagerList);
  295. else
  296. res = Error("问卷列表加载失败");
  297. }
  298. return res;
  299. }
  300. #endregion
  301. #region 问卷设置 - 问卷信息
  302. public ActionResult GetPagerInfoQ(int pid)
  303. {
  304. var model = pagerInfoBLL.GetModel(pid);
  305. if (model != null)
  306. {
  307. //var qlist = questionBLL.GetModelList(" F_DeleteFlag=0 and F_QuestionId in (select F_QuestionId from T_Ask_PagerItems where F_PagerId=" + pid + ") order by F_QuestionId ");
  308. //2018-05-07 实现卷试题排序功能
  309. DataTable dt = DbHelperSQL.Query($" SELECT a.F_Sort,a.F_ItemId,b.* FROM dbo.T_Ask_PagerItems a LEFT JOIN dbo.T_Ask_Question b ON b.F_QuestionId = a.F_QuestionId WHERE a.F_PagerId = " + pid + " AND b.F_DeleteFlag = 0 ORDER BY a.F_ItemId ASC ").Tables[0];
  310. var qlist = DataTableToListHelper.ToList<Ask_QuestionDto>(dt);
  311. var qilist = questionItemBLL.GetModelList(" F_QuestionId in (select F_QuestionId from T_Ask_PagerItems where F_PagerId=" + pid + ") order by F_ItemId ");
  312. var newmodel = new
  313. {
  314. F_Title = model.F_Title,
  315. F_StartText = model.F_StartText,
  316. F_EndText = model.F_EndText,
  317. F_Remark = model.F_Remark,
  318. F_Questions = qlist.Select(q =>
  319. {
  320. return new
  321. {
  322. quesid = q.F_QuestionId,
  323. questitle = q.F_Title,
  324. questype = q.F_Type,
  325. quescontent = q.F_Content,
  326. quesremark = q.F_Remark,
  327. quesitems = qilist.Where(qq => qq.F_QuestionId == q.F_QuestionId).Select(qi =>
  328. {
  329. return new
  330. {
  331. itemid = qi.F_ItemId,
  332. itemname = qi.F_ItemName,
  333. itemremark = qi.F_Remark,
  334. };
  335. })
  336. };
  337. })
  338. };
  339. return Success("获取问卷试题信息成功", newmodel);
  340. }
  341. return Error("获取问卷试题信息失败");
  342. }
  343. public ActionResult GetPagerInfoA(int pid)
  344. {
  345. var model = pagerInfoBLL.GetModel(pid);
  346. //var qlist = questionBLL.GetModelList(" F_DeleteFlag=0 and F_QuestionId in (select F_QuestionId from T_Ask_PagerItems where F_PagerId=" + pid + ") order by F_QuestionId ");
  347. //2018-05-07 lihai 实现卷试题排序功能
  348. DataTable dt = DbHelperSQL.Query($" SELECT a.F_Sort,a.F_ItemId,b.* FROM dbo.T_Ask_PagerItems a LEFT JOIN dbo.T_Ask_Question b ON b.F_QuestionId = a.F_QuestionId WHERE a.F_PagerId = " + pid + " AND b.F_DeleteFlag = 0 ORDER BY a.F_ItemId ASC ").Tables[0];
  349. var qlist = DataTableToListHelper.ToList<Ask_QuestionDto>(dt);
  350. var qilist = questionItemBLL.GetModelList(" F_QuestionId in (select F_QuestionId from T_Ask_PagerItems where F_PagerId=" + pid + ") order by F_ItemId ");
  351. var newmodel = new
  352. {
  353. F_Title = model.F_Title,
  354. F_StartText = model.F_StartText,
  355. F_EndText = model.F_EndText,
  356. F_Remark = model.F_Remark,
  357. F_Questions = qlist.Select(q =>
  358. {
  359. return new
  360. {
  361. quesid = q.F_QuestionId,
  362. questitle = q.F_Title,
  363. questype = q.F_Type,
  364. quescontent = q.F_Content,
  365. quesremark = q.F_Remark,
  366. quesitems = qilist.Where(qq => qq.F_QuestionId == q.F_QuestionId).Select(qi =>
  367. {
  368. return new
  369. {
  370. itemid = qi.F_ItemId,
  371. itemname = qi.F_ItemName,
  372. itemremark = qi.F_Remark,
  373. };
  374. })
  375. };
  376. })
  377. };
  378. return Success("获取问卷试题信息成功", newmodel);
  379. }
  380. #endregion
  381. #region 试题管理 - 试题分类
  382. /// <summary>
  383. /// 试题管理 - 试题分类
  384. /// </summary>
  385. /// <param name="pagesize"></param>
  386. /// <param name="pageindex"></param>
  387. /// <returns></returns>
  388. public ActionResult GetQCategoryList(int pagesize = 10, int pageindex = 1)
  389. {
  390. //if (!Request.IsAuthenticated)
  391. // return NoToken("未知错误,请重新登录");
  392. var recordCount = 0;
  393. var dt = BLL.PagerBLL.GetListPager(
  394. "T_Ask_QuestionCategory",
  395. "F_CategoryId",
  396. "*",
  397. "",
  398. "ORDER BY F_CategoryId desc",
  399. pagesize,
  400. pageindex,
  401. true,
  402. out recordCount);
  403. var obj = new
  404. {
  405. rows = dt,
  406. total = recordCount
  407. };
  408. return Content(obj.ToJson());
  409. }
  410. public ActionResult GetQCategoryAlllist()
  411. {
  412. var alllist = qCategoryBLL.GetModelList(" 1=1 order by F_CategoryId desc");
  413. return Success("获取试题分类成功", alllist);
  414. }
  415. public ActionResult GetQCategoryModel(int id = 0)
  416. {
  417. //if (!Request.IsAuthenticated)
  418. // return NoToken("未知错误,请重新登录");
  419. var model = qCategoryBLL.GetModel(id);
  420. if (model == null)
  421. return Error("当前数据不存在");
  422. return Success("", model);
  423. }
  424. public ActionResult CreateOrUpdateQCategory(int id = 0, string name = "")
  425. {
  426. //if (!Request.IsAuthenticated)
  427. // return NoToken("未知错误,请重新登录");
  428. var model = new Model.T_Ask_QuestionCategory();
  429. if (string.IsNullOrWhiteSpace(name))
  430. return Error("请填写名称" + ",操作人:" + CurrentUser.UserData.F_UserCode);
  431. if (id <= 0)
  432. {
  433. model.F_CategoryName = name;
  434. model.F_CreateOn = DateTime.Now;
  435. model.F_CreateBy = CurrentUser.UserData.F_UserId;
  436. model.F_DeleteFlag = 0;
  437. if (qCategoryBLL.Add(model) > 0)
  438. return Success("添加试题分类成功" + ",操作人:" + CurrentUser.UserData.F_UserCode);
  439. return Error("添加试题分类失败" + ",操作人:" + CurrentUser.UserData.F_UserCode);
  440. }
  441. model = qCategoryBLL.GetModel(id);
  442. model.F_CategoryName = name;
  443. if (qCategoryBLL.Update(model))
  444. return Success("修改试题分类成功" + ",操作人:" + CurrentUser.UserData.F_UserCode);
  445. return Error("修改试题分类失败" + ",操作人:" + CurrentUser.UserData.F_UserCode);
  446. }
  447. public ActionResult DeleteQCategory(int id = 0)
  448. {
  449. //if (!Request.IsAuthenticated)
  450. // return NoToken("未知错误,请重新登录");
  451. if (qCategoryBLL.Delete(id))
  452. return Success("删除试题分类成功" + ",操作人:" + CurrentUser.UserData.F_UserCode);
  453. return Error("删除试题分类失败" + ",操作人:" + CurrentUser.UserData.F_UserCode);
  454. }
  455. #endregion
  456. #region 试题管理 - 试题列表
  457. public ActionResult GetQuestionList(FilterQuestion filter)
  458. {
  459. //if (!Request.IsAuthenticated)
  460. // return NoToken("未知错误,请重新登录");
  461. StringBuilder sb = new StringBuilder();
  462. if (filter.CategoryId > 0)
  463. {
  464. sb.Append(" and F_CategoryId=" + filter.CategoryId);
  465. }
  466. if (filter.SelectType > 0)
  467. {
  468. sb.Append(" and F_Type=" + filter.SelectType);
  469. }
  470. if (!string.IsNullOrWhiteSpace(filter.Key))
  471. {
  472. sb.Append(" and (F_Title like '%" + filter.Key + "%' or F_Content like '%" + filter.Key + "%') ");
  473. }
  474. var recordCount = 0;
  475. var dt = BLL.PagerBLL.GetListPager(
  476. "vw_Ask_Question",
  477. "F_QuestionId",
  478. "*",
  479. " and F_DeleteFlag=0 " + sb.ToString(),
  480. "ORDER BY F_QuestionId desc",
  481. filter.PageSize,
  482. filter.PageIndex,
  483. true,
  484. out recordCount);
  485. var quesitemlist = questionItemBLL.GetModelList("");
  486. for (int i = 0; i < dt.Rows.Count; i++)
  487. {
  488. var items = "";
  489. string qid = dt.Rows[i]["F_QuestionId"].ToString();
  490. var quesitem = quesitemlist.Where(qi => qi.F_QuestionId == int.Parse(qid));
  491. if (quesitem.Count() > 0)
  492. {
  493. foreach (var item in quesitem)
  494. {
  495. items += ";" + item.F_ItemName;
  496. }
  497. }
  498. dt.Rows[i]["F_Content"] = items.Trim(';');
  499. }
  500. var obj = new
  501. {
  502. rows = dt,
  503. total = recordCount
  504. };
  505. return Content(obj.ToJson());
  506. }
  507. public ActionResult GetQuestionModel(int id = 0)
  508. {
  509. if (id <= 0)
  510. return Error("参数不正确");
  511. var model = questionBLL.GetModel(id);
  512. if (model == null)
  513. return Error("当前数据不存在");
  514. return Success("获取试题成功", model);
  515. }
  516. public ActionResult CreateOrUpdateQuestion(QuesttionInput input)
  517. {
  518. DataTable dt = new DataTable();
  519. var model = new Model.T_Ask_Question();
  520. if (string.IsNullOrWhiteSpace(input.F_Title))
  521. return Error("请填写试题标题" + ",操作人:" + CurrentUser.UserData.F_UserCode);
  522. //20180519 zhengbingbing
  523. #region 此模块暂时无用
  524. ////1问答题 2单选题 3多选题
  525. //if (input.F_Type > 1)
  526. //{
  527. // //var questionItemList = questionItemBLL.DataTableToList(questionItemBLL.GetList($" F_QuestionId='{input.F_QuestionId}' ORDER BY F_Sort ").Tables[0]);
  528. // #region 获取内容F_Content,格式:A.满意;B.一般;C.不满意;
  529. // string[] arr1 = new string[] { "1", "2", "3", "4", "5", "6", "7", "8", "9", "10", "11", "12", "13", "14", "15", "16", "17", "18", "19", "20" };
  530. // string[] arr2 = new string[] { "A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T" };
  531. // dt = new BLL.T_Ask_QuestionItems().GetList(" F_QuestionId=" + input.F_QuestionId + " ORDER BY F_Sort ").Tables[0];
  532. // for (int i = 0; i < dt.Rows.Count; i++)
  533. // {
  534. // string vsort = "";
  535. // if (input.F_SortModel == 1)
  536. // {
  537. // vsort = arr2[i];
  538. // }
  539. // else
  540. // {
  541. // vsort = arr1[i];
  542. // }
  543. // input.F_Content += vsort + "." + dt.Rows[i]["F_ItemName"].ToString().Trim() + ";";
  544. // }
  545. // model.F_SortModel = input.F_SortModel;
  546. // #endregion
  547. //}
  548. //else
  549. //{
  550. // model.F_SortModel = null;
  551. //}
  552. #endregion
  553. if (input.F_QuestionId <= 0)
  554. {
  555. //model.F_SortModel = input.F_SortModel;
  556. model.F_QuestionId = CurrentUser.UserData.F_UserId;
  557. model.F_CategoryId = input.F_CategoryId;
  558. model.F_Type = input.F_Type;
  559. model.F_Title = input.F_Title;
  560. model.F_Content = input.F_Content;
  561. model.F_Remark = input.F_Remark;
  562. model.F_CreateOn = DateTime.Now;
  563. model.F_CreateBy = CurrentUser.UserData.F_UserId;
  564. model.F_ModifyOn = DateTime.Now;
  565. model.F_ModifyBy = CurrentUser.UserData.F_UserId;
  566. model.F_DeleteFlag = 0;
  567. if (questionBLL.Add(model) > 0)
  568. return Success("添加试题成功" + ",操作人:" + CurrentUser.UserData.F_UserCode);
  569. return Error("添加试题失败" + ",操作人:" + CurrentUser.UserData.F_UserCode);
  570. }
  571. model = questionBLL.GetModel(input.F_QuestionId);
  572. //model.F_SortModel = input.F_SortModel;
  573. model.F_CategoryId = input.F_CategoryId;
  574. model.F_Title = input.F_Title;
  575. model.F_Type = input.F_Type;
  576. model.F_Content = input.F_Content;
  577. model.F_Remark = input.F_Remark;
  578. model.F_ModifyOn = DateTime.Now;
  579. model.F_ModifyBy = CurrentUser.UserData.F_UserId;
  580. if (questionBLL.Update(model))
  581. return Success("修改试题成功" + ",操作人:" + CurrentUser.UserData.F_UserCode);
  582. return Error("修改试题失败" + ",操作人:" + CurrentUser.UserData.F_UserCode);
  583. }
  584. /// <summary>
  585. /// 删除试题列表(删除两表信息)
  586. /// </summary>
  587. /// <param name="id"></param>
  588. /// <returns></returns>
  589. public ActionResult DeleteQuestion(int id = 0)
  590. {
  591. if (questionBLL.Delete(id))
  592. {
  593. questionItemBLL.DeleteByQuestionId(id); ;
  594. return Success("删除试题成功" + ",操作人:" + CurrentUser.UserData.F_UserCode); ;
  595. }
  596. else
  597. {
  598. return Error("删除试题失败!" + ",操作人:" + CurrentUser.UserData.F_UserCode);
  599. }
  600. }
  601. #endregion
  602. #region 试题管理 - 试题列表 -- 问题答案管理
  603. public ActionResult GetQuestionItemList(int pagesize = 10, int pageindex = 1, int id = 0)
  604. {
  605. //if (!Request.IsAuthenticated)
  606. // return NoToken("未知错误,请重新登录");
  607. var sql = "";
  608. if (id > 0)
  609. {
  610. sql = " and F_QuestionId=" + id;
  611. }
  612. var recordCount = 0;
  613. var dt = BLL.PagerBLL.GetListPager(
  614. "T_Ask_QuestionItems",
  615. "F_ItemId",
  616. "*",
  617. " " + sql,
  618. "ORDER BY F_Sort ",
  619. pagesize,
  620. pageindex,
  621. true,
  622. out recordCount);
  623. var obj = new
  624. {
  625. rows = dt,
  626. total = recordCount
  627. };
  628. return Content(obj.ToJson());
  629. }
  630. public ActionResult GetQuestionItemModel(int id = 0)
  631. {
  632. var model = questionItemBLL.GetModel(id);
  633. if (model == null)
  634. return Error("当前数据不存在");
  635. return Success("", model);
  636. }
  637. public ActionResult CreateOrUpdateQuestionItem(QuesttionItemInput input)
  638. {
  639. var model = new Model.T_Ask_QuestionItems();
  640. if (input.Id <= 0)
  641. {
  642. model.F_ItemName = input.Name;
  643. model.F_QuestionId = input.QuestionId;
  644. model.F_Remark = input.Remark;
  645. //model.F_IsAnswer = input.IsAnswer;
  646. //model.F_Sort = input.Sort;
  647. //model.F_SortModel = input.SortMode;
  648. if (questionItemBLL.Add(model) > 0)
  649. return Success("添加试题选项成功" + ",操作人:" + CurrentUser.UserData.F_UserCode);
  650. return Error("添加试题选项失败" + ",操作人:" + CurrentUser.UserData.F_UserCode);
  651. }
  652. model = questionItemBLL.GetModel(input.Id);
  653. model.F_ItemName = input.Name;
  654. model.F_QuestionId = input.QuestionId;
  655. model.F_Remark = input.Remark;
  656. //model.F_IsAnswer = input.IsAnswer;
  657. //model.F_Sort = input.Sort;
  658. //model.F_SortModel = input.SortMode;
  659. if (questionItemBLL.Update(model))
  660. return Success("修改试题选项成功" + ",操作人:" + CurrentUser.UserData.F_UserCode);
  661. return Error("修改试题选项失败" + ",操作人:" + CurrentUser.UserData.F_UserCode);
  662. }
  663. public ActionResult DeleteQuestionItme(int id = 0)
  664. {
  665. if (questionItemBLL.Delete(id))
  666. return Success("删除试题选项成功" + ",操作人:" + CurrentUser.UserData.F_UserCode);
  667. return Error("删除试题选项失败" + ",操作人:" + CurrentUser.UserData.F_UserCode);
  668. }
  669. #endregion
  670. #region 问卷调查报告数据简单查询
  671. public ActionResult GetReport()
  672. {
  673. ActionResult res = NoToken("未知错误,请重新登录");
  674. string TaskName = HttpUtility.UrlDecode(RequestString.GetQueryString("taskname"));
  675. DataTable dtnew = new DataTable();
  676. dtnew.Columns.Add("wenti");
  677. dtnew.Columns.Add("xuanxiang");
  678. dtnew.Columns.Add("shuliang");
  679. dtnew.Columns.Add("bili");
  680. //根据任务名获取任务ID
  681. string TaskID = "";
  682. var objo = DbHelperSQL.GetSingle("select F_TaskID from T_Call_OutTask where F_TaskName='" + TaskName + "'");
  683. if (objo != null)
  684. {
  685. TaskID = objo.ToString();
  686. }
  687. //List<Model.T_Ask_Question> qrlist = new List<Model.T_Ask_Question>();
  688. DataSet ds = DbHelperSQL.Query("SELECT * FROM T_Ask_Question WHERE F_QuestionId IN (select ta.F_QuestionId from T_Ask_PagerItems ta where ta.F_PagerId=(select F_PagerID from T_Call_OutTask where F_TaskID='" + TaskID + "') ) and F_Type!=1");
  689. if (ds != null && ds.Tables.Count > 0)
  690. {
  691. DataTable dt = ds.Tables[0];
  692. for (int i = 0; i < dt.Rows.Count; i++)
  693. {
  694. string content = dt.Rows[i]["F_Content"].ToString();
  695. string question = dt.Rows[i]["F_Title"].ToString();
  696. string[] item = content.Split(';');
  697. //根据问题ID获取当前问题各选项答案总数
  698. int totalnum = 0;
  699. object obj0 = DbHelperSQL.GetSingle("select COUNT(1) from T_Call_OutAnswers WHERE F_TaskID='" + TaskID + "' and F_QID='" + dt.Rows[i]["F_QuestionId"].ToString() + "' ");
  700. if (obj0 != null && obj0.ToString() != "")
  701. {
  702. totalnum = Convert.ToInt32(obj0);
  703. }
  704. //根据问题ID查询问题项
  705. DataSet dsi = DbHelperSQL.Query("SELECT* FROM T_Ask_QuestionItems where F_QuestionId = '" + dt.Rows[i]["F_QuestionId"].ToString() + "'");
  706. if (dsi != null && dsi.Tables.Count > 0)
  707. {
  708. for (int j = 0; j < dsi.Tables[0].Rows.Count; j++)
  709. {
  710. string itemname = dsi.Tables[0].Rows[j]["F_ItemName"].ToString();
  711. DataRow dr = dtnew.NewRow();
  712. dr["wenti"] = question;
  713. dr["xuanxiang"] = itemname;
  714. //DataSet dss = DbHelperSQL.Query("select COUNT(1) from T_Call_OutAnswers WHERE F_TaskID='"+ TaskID + "' and F_Answer='"+ item[j].ToString() + "' group by F_QID");
  715. object obj = DbHelperSQL.GetSingle("select COUNT(1) from T_Call_OutAnswers WHERE F_TaskID='" + TaskID + "' and F_Answer='" + itemname + "' and F_QID='" + dt.Rows[i]["F_QuestionId"].ToString() + "' ");
  716. if (obj != null && obj.ToString() != "")
  717. {
  718. int num = Convert.ToInt32(obj);
  719. dr["shuliang"] = num;
  720. if (totalnum != 0)
  721. {
  722. if (num > 0)
  723. {
  724. dr["bili"] = (num / totalnum * 100).ToString() + "%";
  725. }
  726. else
  727. {
  728. dr["bili"] = "0";
  729. }
  730. }
  731. else
  732. { dr["bili"] = "0"; }
  733. }
  734. else
  735. {
  736. dr["shuliang"] = "0";
  737. dr["bili"] = "0";
  738. }
  739. dtnew.Rows.Add(dr);
  740. }
  741. }
  742. //for (int j = 0; j < item.Length; j++)
  743. //{
  744. // if (item[j].Length > 0)
  745. // {
  746. // DataRow dr = dtnew.NewRow();
  747. // dr["wenti"] = question;
  748. // dr["xuanxiang"] = item[j].ToString();
  749. // //DataSet dss = DbHelperSQL.Query("select COUNT(1) from T_Call_OutAnswers WHERE F_TaskID='"+ TaskID + "' and F_Answer='"+ item[j].ToString() + "' group by F_QID");
  750. // object obj = DbHelperSQL.GetSingle("select COUNT(1) from T_Call_OutAnswers WHERE F_TaskID='" + TaskID + "' and F_Answer='" + item[j].ToString() + "' group by F_QID");
  751. // if (obj != null && obj.ToString() != "")
  752. // {
  753. // int num = Convert.ToInt32(obj);
  754. // dr["shuliang"] = num;
  755. // if (totalnum != 0)
  756. // {
  757. // dr["bili"] = (num / totalnum * 100).ToString() + "%";
  758. // }
  759. // }
  760. // dtnew.Rows.Add(dr);
  761. // }
  762. //}
  763. }
  764. }
  765. res = Success("获取调查报表数据成功", dtnew);
  766. return res;
  767. }
  768. #endregion
  769. #region 问卷调查报表数据查询
  770. List<string> arlist = new List<string>();//表头问题分项
  771. List<string> checklist = new List<string>();//查询条件问题分项
  772. DataTable dtNews = new DataTable();
  773. DataTable dtCol = new DataTable();
  774. int columnsnum = 1;//左边留一空列,用于显示查询条件答案
  775. int questioncount = 0;
  776. //获取表头
  777. public ActionResult GetColumnList()
  778. {
  779. ActionResult res = NoToken("未知错误,请重新登录");
  780. string TaskName = HttpUtility.UrlDecode(RequestString.GetQueryString("taskname"));
  781. string Question = HttpUtility.UrlDecode(RequestString.GetQueryString("question"));
  782. //TaskName = "白居易";
  783. string TaskID = "";
  784. var obj = DbHelperSQL.GetSingle("select F_TaskID from T_Call_OutTask where F_TaskName='" + TaskName + "'");
  785. if (obj != null)
  786. {
  787. TaskID = obj.ToString();
  788. }
  789. columnsnum = 1;
  790. arlist.Clear();
  791. checklist.Clear();
  792. //dtCol.Rows.Clear();
  793. //dtCol.Columns.Clear();
  794. dtCol.Columns.Add("wenti", Type.GetType("System.String"));
  795. //dtCol.Columns.Add(new DataColumn("wenti", Type.GetType("System.String")));
  796. dtCol.Columns.Add("fenxiangshu", Type.GetType("System.Int32"));
  797. dtCol.Columns.Add("wentiid", Type.GetType("System.String"));
  798. DataSet ds = DbHelperSQL.Query("SELECT * FROM T_Ask_Question WHERE F_QuestionId IN (select ta.F_QuestionId from T_Ask_PagerItems ta where ta.F_PagerId=(select F_PagerID from T_Call_OutTask where F_TaskID='" + TaskID + "') ) and F_Type!=1");
  799. if (ds != null && ds.Tables.Count > 0)
  800. {
  801. DataTable dt = ds.Tables[0];
  802. questioncount = dt.Rows.Count;
  803. for (int i = 0; i < dt.Rows.Count; i++)
  804. {
  805. string content = dt.Rows[i]["F_Content"].ToString();//问题选项
  806. string questions = dt.Rows[i]["F_Title"].ToString();//问题
  807. string questionid = dt.Rows[i]["F_QuestionId"].ToString();//问题
  808. string[] rowheader = content.Split(';');
  809. if (questions != Question)
  810. {
  811. DataRow dr = dtCol.NewRow();
  812. dr["wenti"] = questions;
  813. //根据问题ID查询问题项
  814. DataSet dsi = DbHelperSQL.Query("SELECT* FROM T_Ask_QuestionItems where F_QuestionId = (select F_QuestionId from T_Ask_Question where F_Title='" + questions + "')");
  815. if (dsi != null && dsi.Tables.Count > 0)
  816. {
  817. for (int j = 0; j < dsi.Tables[0].Rows.Count; j++)
  818. {
  819. arlist.Add(dsi.Tables[0].Rows[j]["F_ItemName"].ToString());
  820. columnsnum++;
  821. }
  822. dr["fenxiangshu"] = dsi.Tables[0].Rows.Count;
  823. }
  824. //dr["fenxiangshu"] = dt.Rows.Count;
  825. dr["wentiid"] = questionid;
  826. dtCol.Rows.Add(dr);
  827. // for (int j = 0; j < rowheader.Length; j++)
  828. //{
  829. // if (rowheader[j].Length > 0)
  830. // {
  831. // arlist.Add(rowheader[j]);
  832. // columnsnum++;
  833. // }
  834. //}
  835. }
  836. else
  837. {
  838. //根据问题ID查询问题项
  839. DataSet dsi = DbHelperSQL.Query("SELECT* FROM T_Ask_QuestionItems where F_QuestionId = (select F_QuestionId from T_Ask_Question where F_Title='" + questions + "')");
  840. if (dsi != null && dsi.Tables.Count > 0)
  841. {
  842. for (int j = 0; j < dsi.Tables[0].Rows.Count; j++)
  843. {
  844. checklist.Add(dsi.Tables[0].Rows[j]["F_ItemName"].ToString());
  845. }
  846. }
  847. //for (int j = 0; j < rowheader.Length; j++)
  848. //{
  849. // if (rowheader[j].Length > 0)
  850. // {
  851. // checklist.Add(rowheader[j]);
  852. // }
  853. //}
  854. }
  855. }
  856. }
  857. res = Success("获取调查问卷表头成功", dtCol);
  858. return res;
  859. }
  860. //获取数据
  861. public ActionResult GetDataList()
  862. {
  863. ActionResult res = NoToken("未知错误,请重新登录");
  864. string TaskName = HttpUtility.UrlDecode(RequestString.GetQueryString("taskname"));
  865. string Question = HttpUtility.UrlDecode(RequestString.GetQueryString("question"));
  866. int index1 = 0;
  867. int index2 = 0;
  868. GetColumnList();
  869. int rowcount = checklist.Count + 1;//行数
  870. string[,] newdata = new string[rowcount, columnsnum];
  871. string TaskID = "";
  872. var obj0 = DbHelperSQL.GetSingle("select F_TaskID from T_Call_OutTask where F_TaskName='" + TaskName + "'");
  873. if (obj0 != null)
  874. {
  875. TaskID = obj0.ToString();
  876. }
  877. string QID = "";
  878. var obj1 = DbHelperSQL.GetSingle("select F_QuestionId from T_Ask_Question where F_Title='" + Question + "' and F_Type!=1");
  879. if (obj1 != null)
  880. {
  881. QID = obj1.ToString();
  882. }
  883. //for (int i = 0; i < columnsnum; i++)
  884. //{
  885. // dtNews.Columns.Add("Column" + (i + 1).ToString(), Type.GetType("System.String"));
  886. //}
  887. //添加问题选项
  888. //DataRow dr = dtNews.NewRow();
  889. //dr["Column1"] = "";
  890. newdata[index1, index2] = "";
  891. index2++;
  892. for (int j = 0; j < arlist.Count; j++)
  893. {
  894. //dr["Column" + (j + 2).ToString()] = arlist[j];
  895. newdata[index1, index2] = arlist[j];
  896. index2++;
  897. }
  898. //dtNews.Rows.Add(dr);
  899. index1++;//第一行添加结束
  900. //获取百分比
  901. List<string> rowlist = new List<string>();
  902. foreach (string items in checklist)
  903. {
  904. //rowlist.Clear();
  905. //rowlist.Add(items);
  906. int colnum = 2;
  907. index2 = 0;
  908. DataRow drr = dtNews.NewRow();
  909. //drr["Column1"] = items;
  910. newdata[index1, index2] = items;
  911. int n = 0;
  912. int len = 0;
  913. for (int m = 0; m < dtCol.Rows.Count; m++)
  914. {
  915. //根据问题查询回答该问题的总次数
  916. int totalnum = 0;
  917. int num = 0;
  918. object obj = DbHelperSQL.GetSingle("SELECT COUNT(1) FROM T_Call_OutAnswers WHERE F_CusTelID IN (select F_CusTelID from T_Call_OutAnswers where F_TaskID='" + TaskID + "' AND F_QID='" + QID + "' AND F_Answer='" + items + "') AND F_QID='" + dtCol.Rows[m]["wentiid"].ToString() + "'");//
  919. if (obj != null && obj.ToString() != "")
  920. {
  921. totalnum = Convert.ToInt32(obj);
  922. }
  923. int fenxiang = Convert.ToInt32(dtCol.Rows[m]["fenxiangshu"].ToString());
  924. len = len + fenxiang;
  925. while (n < len)
  926. {
  927. index2++;
  928. //同一问题下的分项
  929. object obj2 = DbHelperSQL.GetSingle("SELECT COUNT(1) FROM T_Call_OutAnswers WHERE F_CusTelID IN (select F_CusTelID from T_Call_OutAnswers where F_TaskID='" + TaskID + "' AND F_QID='" + QID + "' AND F_Answer='" + items + "') AND F_QID='" + dtCol.Rows[m]["wentiid"].ToString() + "' and F_Answer='" + newdata[0, n + 1] + "'");//dtNews.Rows[0]["Column" + colnum.ToString()].ToString()
  930. if (obj2 != null && obj2.ToString() != "")
  931. {
  932. num = Convert.ToInt32(obj2);
  933. }
  934. if (totalnum > 0)
  935. {
  936. //drr["Column" + colnum.ToString()] = (num / totalnum * 100).ToString() + "%";
  937. if (num > 0)
  938. {
  939. newdata[index1, index2] = (num / totalnum * 100).ToString() + "%";
  940. }
  941. else
  942. { newdata[index1, index2] = "0"; }
  943. }
  944. else
  945. { newdata[index1, index2] = "0"; }
  946. n++;
  947. }
  948. colnum++;
  949. }
  950. index1++;
  951. //dtNews.Rows.Add(drr);
  952. }
  953. res = Success("获取调查问卷报表数据成功", newdata);
  954. return res;
  955. }
  956. #endregion
  957. #region 查询条件
  958. /// <summary>
  959. /// 获取任务名列表
  960. /// </summary>
  961. /// <returns></returns>
  962. public ActionResult GetTaskList()
  963. {
  964. if (Request.IsAuthenticated)
  965. {
  966. DataTable dt = new DataTable();
  967. dt = new BLL.T_Call_OutTask().GetList(" F_DeleteFlag=0 ").Tables[0];
  968. return Success("加载成功", dt);
  969. }
  970. return NoToken("未知错误,请重新登录");
  971. }
  972. /// <summary>
  973. /// 获取问题列表
  974. /// </summary>
  975. /// <returns></returns>
  976. public ActionResult GetQList()
  977. {
  978. if (Request.IsAuthenticated)
  979. {
  980. DataTable dt = new DataTable();
  981. dt = new BLL.T_Ask_Question().GetList(" F_Type!=1").Tables[0];
  982. return Success("加载成功", dt);
  983. }
  984. return NoToken("未知错误,请重新登录");
  985. }
  986. #endregion
  987. //导出Excel
  988. #region 导出Excel
  989. #region 问卷调查报告数据简单查询导出Excel
  990. public ActionResult GetReportExpt()
  991. {
  992. ActionResult res = NoToken("未知错误,请重新登录");
  993. string TaskName = HttpUtility.UrlDecode(RequestString.GetQueryString("taskname"));
  994. DataTable dtnew = new DataTable();
  995. dtnew.Columns.Add("wenti");
  996. dtnew.Columns.Add("xuanxiang");
  997. dtnew.Columns.Add("shuliang");
  998. dtnew.Columns.Add("bili");
  999. //根据任务名获取任务ID
  1000. string TaskID = "";
  1001. var objo = DbHelperSQL.GetSingle("select F_TaskID from T_Call_OutTask where F_TaskName='" + TaskName + "'");
  1002. if (objo != null)
  1003. {
  1004. TaskID = objo.ToString();
  1005. }
  1006. //List<Model.T_Ask_Question> qrlist = new List<Model.T_Ask_Question>();
  1007. DataSet ds = DbHelperSQL.Query("SELECT * FROM T_Ask_Question WHERE F_QuestionId IN (select ta.F_QuestionId from T_Ask_PagerItems ta where ta.F_PagerId=(select F_PagerID from T_Call_OutTask where F_TaskID='" + TaskID + "') ) and F_Type!=1");
  1008. if (ds != null && ds.Tables.Count > 0)
  1009. {
  1010. DataTable dt = ds.Tables[0];
  1011. for (int i = 0; i < dt.Rows.Count; i++)
  1012. {
  1013. string content = dt.Rows[i]["F_Content"].ToString();
  1014. string question = dt.Rows[i]["F_Title"].ToString();
  1015. string[] item = content.Split(';');
  1016. //根据问题ID获取当前问题各选项答案总数
  1017. int totalnum = 0;
  1018. object obj0 = DbHelperSQL.GetSingle("select COUNT(1) from T_Call_OutAnswers WHERE F_TaskID='" + TaskID + "' and F_QID='" + dt.Rows[i]["F_QuestionId"].ToString() + "' ");
  1019. if (obj0 != null && obj0.ToString() != "")
  1020. {
  1021. totalnum = Convert.ToInt32(obj0);
  1022. }
  1023. //根据问题ID查询问题项
  1024. DataSet dsi = DbHelperSQL.Query("SELECT* FROM T_Ask_QuestionItems where F_QuestionId = '" + dt.Rows[i]["F_QuestionId"].ToString() + "'");
  1025. if (dsi != null && dsi.Tables.Count > 0)
  1026. {
  1027. for (int j = 0; j < dsi.Tables[0].Rows.Count; j++)
  1028. {
  1029. string itemname = dsi.Tables[0].Rows[j]["F_ItemName"].ToString();
  1030. DataRow dr = dtnew.NewRow();
  1031. dr["wenti"] = question;
  1032. dr["xuanxiang"] = itemname;
  1033. //DataSet dss = DbHelperSQL.Query("select COUNT(1) from T_Call_OutAnswers WHERE F_TaskID='"+ TaskID + "' and F_Answer='"+ item[j].ToString() + "' group by F_QID");
  1034. object obj = DbHelperSQL.GetSingle("select COUNT(1) from T_Call_OutAnswers WHERE F_TaskID='" + TaskID + "' and F_Answer='" + itemname + "' and F_QID='" + dt.Rows[i]["F_QuestionId"].ToString() + "' ");
  1035. if (obj != null && obj.ToString() != "")
  1036. {
  1037. int num = Convert.ToInt32(obj);
  1038. dr["shuliang"] = num;
  1039. if (totalnum != 0)
  1040. {
  1041. if (num > 0)
  1042. {
  1043. dr["bili"] = (num / totalnum * 100).ToString() + "%";
  1044. }
  1045. else
  1046. {
  1047. dr["bili"] = "0";
  1048. }
  1049. }
  1050. else
  1051. { dr["bili"] = "0"; }
  1052. }
  1053. else
  1054. {
  1055. dr["shuliang"] = "0";
  1056. dr["bili"] = "0";
  1057. }
  1058. dtnew.Rows.Add(dr);
  1059. }
  1060. }
  1061. }
  1062. }
  1063. //导出dtnew
  1064. NPOIHelper npoi = new NPOIHelper();
  1065. string[] col = { "问题", "选项", "数量", "比例" };
  1066. if (npoi.ExportToExcel("问卷调查报告统计数据", dtnew, col) == "")
  1067. {
  1068. return Success("导出成功");
  1069. }
  1070. else
  1071. {
  1072. return Error("导出失败");
  1073. }
  1074. }
  1075. #endregion
  1076. #region 导出按任务和问题查询出的数据
  1077. public ActionResult GetDataListExpt()
  1078. {
  1079. ActionResult res = NoToken("未知错误,请重新登录");
  1080. string TaskName = HttpUtility.UrlDecode(RequestString.GetQueryString("taskname"));
  1081. string Question = HttpUtility.UrlDecode(RequestString.GetQueryString("question"));
  1082. GetColumnList();
  1083. string TaskID = "";
  1084. var obj0 = DbHelperSQL.GetSingle("select F_TaskID from T_Call_OutTask where F_TaskName='" + TaskName + "'");
  1085. if (obj0 != null)
  1086. {
  1087. TaskID = obj0.ToString();
  1088. }
  1089. string QID = "";
  1090. var obj1 = DbHelperSQL.GetSingle("select F_QuestionId from T_Ask_Question where F_Title='" + Question + "' and F_Type!=1");
  1091. if (obj1 != null)
  1092. {
  1093. QID = obj1.ToString();
  1094. }
  1095. for (int i = 0; i < columnsnum; i++)
  1096. {
  1097. dtNews.Columns.Add("Column" + (i + 1).ToString(), Type.GetType("System.String"));
  1098. }
  1099. //添加第一行
  1100. DataRow dr0 = dtNews.NewRow();
  1101. dr0["Column1"] = Question;
  1102. int cindex = 2;
  1103. for (int i = 0; i < dtCol.Rows.Count; i++)
  1104. {
  1105. int itemcount = Convert.ToInt32(dtCol.Rows[i]["fenxiangshu"]);
  1106. for (int j = 0; j < itemcount; j++)
  1107. {
  1108. dr0["Column" + cindex] = dtCol.Rows[i]["wenti"];
  1109. cindex++;
  1110. }
  1111. }
  1112. dtNews.Rows.Add(dr0);
  1113. //添加问题选项
  1114. DataRow dr = dtNews.NewRow();
  1115. dr["Column1"] = "";
  1116. for (int j = 0; j < arlist.Count; j++)
  1117. {
  1118. dr["Column" + (j + 2).ToString()] = arlist[j];
  1119. }
  1120. dtNews.Rows.Add(dr);
  1121. //获取百分比
  1122. List<string> rowlist = new List<string>();
  1123. foreach (string items in checklist)
  1124. {
  1125. //rowlist.Clear();
  1126. //rowlist.Add(items);
  1127. int colnum = 2;
  1128. int n = 0;
  1129. int len = 0;
  1130. DataRow drr = dtNews.NewRow();
  1131. drr["Column1"] = items;
  1132. for (int m = 0; m < dtCol.Rows.Count; m++)
  1133. {
  1134. //根据问题查询回答该问题的总次数
  1135. int totalnum = 0;
  1136. int num = 0;
  1137. object obj = DbHelperSQL.GetSingle("SELECT COUNT(1) FROM T_Call_OutAnswers WHERE F_CusTelID IN (select F_CusTelID from T_Call_OutAnswers where F_TaskID='" + TaskID + "' AND F_QID='" + QID + "' AND F_Answer='" + items + "') AND F_QID='" + dtCol.Rows[m]["wentiid"].ToString() + "'");//
  1138. if (obj != null && obj.ToString() != "")
  1139. {
  1140. totalnum = Convert.ToInt32(obj);
  1141. }
  1142. #region
  1143. int fenxiang = Convert.ToInt32(dtCol.Rows[m]["fenxiangshu"].ToString());
  1144. len = len + fenxiang;
  1145. while (n < len)
  1146. {
  1147. //同一问题下的分项
  1148. object obj2 = DbHelperSQL.GetSingle("SELECT COUNT(1) FROM T_Call_OutAnswers WHERE F_CusTelID IN (select F_CusTelID from T_Call_OutAnswers where F_TaskID='" + TaskID + "' AND F_QID='" + QID + "' AND F_Answer='" + items + "') AND F_QID='" + dtCol.Rows[m]["wentiid"].ToString() + "' and F_Answer='" + dtNews.Rows[1]["Column" + colnum.ToString()].ToString() + "'");
  1149. if (obj2 != null && obj2.ToString() != "")
  1150. {
  1151. num = Convert.ToInt32(obj2);
  1152. }
  1153. if (totalnum > 0)
  1154. {
  1155. //drr["Column" + colnum.ToString()] = (num / totalnum * 100).ToString() + "%";
  1156. if (num > 0)
  1157. {
  1158. drr["Column" + colnum.ToString()] = (num / totalnum * 100).ToString() + "%";
  1159. }
  1160. else
  1161. { drr["Column" + colnum.ToString()] = "0"; }
  1162. }
  1163. else
  1164. { drr["Column" + colnum.ToString()] = "0"; }
  1165. n++;
  1166. colnum++;
  1167. }
  1168. #endregion
  1169. #region 无用
  1170. //同一问题下的分项
  1171. /*object obj2 = DbHelperSQL.GetSingle("SELECT COUNT(1) FROM T_Call_OutAnswers WHERE F_CusTelID IN (select F_CusTelID from T_Call_OutAnswers where F_TaskID='" + TaskID + "' AND F_QID='" + QID + "' AND F_Answer='" + items + "') AND F_QID='" + dtCol.Rows[m]["wentiid"].ToString() + "' and F_Answer='" + dtNews.Rows[1]["Column" + colnum.ToString()].ToString() + "'");//
  1172. if (obj2 != null && obj2.ToString() != "")
  1173. {
  1174. num = Convert.ToInt32(obj2);
  1175. }
  1176. if (totalnum > 0)
  1177. {
  1178. if (num > 0)
  1179. {
  1180. drr["Column" + colnum.ToString()] = (num / totalnum * 100).ToString() + "%";
  1181. }
  1182. else
  1183. { drr["Column" + colnum.ToString()] = "0"; }
  1184. }*/
  1185. #endregion
  1186. }
  1187. dtNews.Rows.Add(drr);
  1188. }
  1189. //res = Success("获取调查问卷报表数据成功", dtNews);
  1190. //return res;
  1191. //导出dtnew
  1192. NPOIHelper npoi = new NPOIHelper();
  1193. if (npoi.ExportToExcel2("问卷调查报告统计数据", dtNews) == "")
  1194. {
  1195. return Success("导出成功");
  1196. }
  1197. else
  1198. {
  1199. return Error("导出失败");
  1200. }
  1201. }
  1202. #endregion
  1203. #endregion
  1204. //2017-11-14
  1205. #region 数据查询--获取排名
  1206. public ActionResult GetRank()
  1207. {
  1208. ActionResult res = NoToken("未知错误,请重新登录");
  1209. string startdate = HttpUtility.UrlDecode(RequestString.GetQueryString("startdate")) + " 00:00:00";
  1210. string enddate = HttpUtility.UrlDecode(RequestString.GetQueryString("enddate")) + " 23:59:59";
  1211. //startdate = "2017-11-12 00:00:00";
  1212. //enddate = "2017-11-14 23:59:59";
  1213. if (HttpUtility.UrlDecode(RequestString.GetQueryString("startdate")) == null || HttpUtility.UrlDecode(RequestString.GetQueryString("startdate")) == "")
  1214. {
  1215. startdate = DateTime.Now.ToString("yyyy-MM-dd") + " 00:00:00";
  1216. //enddate = DateTime.Now.ToString("yyyy-MM-dd") + " 23:59:59";
  1217. }
  1218. if (HttpUtility.UrlDecode(RequestString.GetQueryString("enddate")) == null || HttpUtility.UrlDecode(RequestString.GetQueryString("enddate")) == "")
  1219. {
  1220. //startdate = DateTime.Now.ToString("yyyy-MM-dd") + " 00:00:00";
  1221. enddate = DateTime.Now.ToString("yyyy-MM-dd") + " 23:59:59";
  1222. }
  1223. DataTable dtnew = new DataTable();
  1224. dtnew.Columns.Add("xiangzhen", Type.GetType("System.String"));
  1225. dtnew.Columns.Add("zongshu", Type.GetType("System.Int32"));
  1226. dtnew.Columns.Add("buanquan", Type.GetType("System.Int32"));
  1227. dtnew.Columns.Add("zhishu", Type.GetType("System.Decimal"));
  1228. int leiji = 0;
  1229. int buanquanleiji = 0;
  1230. //List<Model.T_Ask_Question> qrlist = new List<Model.T_Ask_Question>();
  1231. //DataSet ds = DbHelperSQL.Query("SELECT * FROM T_Ask_QuestionItems WHERE F_ItemId IN (SELECT F_QIID FROM T_Call_OutAnswers WHERE F_CusTelID IN (select F_CusTelID from T_Call_OutAnswers where F_OptOn between '"+startdate+"' and '"+enddate +"' and F_QID=102 ) and F_QID=101 group by F_QIID)");//and (F_QIID=101 OR F_QIID=102)
  1232. DataSet ds = DbHelperSQL.Query("SELECT * FROM T_Ask_QuestionItems where F_QuestionId='101'");// WHERE F_ItemId IN (SELECT F_QIID FROM T_Call_OutAnswers WHERE F_CusTelID IN (select F_CusTelID from T_Call_OutAnswers where F_OptOn between '" + startdate + "' and '" + enddate + "' and F_QID=102 ) and F_QID=101 group by F_QIID)");
  1233. if (ds != null && ds.Tables.Count > 0)
  1234. {
  1235. DataTable dt = ds.Tables[0];
  1236. for (int i = 0; i < dt.Rows.Count; i++)
  1237. {
  1238. DataRow dr = dtnew.NewRow();
  1239. string content = dt.Rows[i]["F_ItemName"].ToString();
  1240. string ItemID = dt.Rows[i]["F_ItemID"].ToString();
  1241. dr["xiangzhen"] = content;
  1242. //根据乡镇获取不安全数
  1243. int unsafenum = 0;
  1244. object obj0 = DbHelperSQL.GetSingle("SELECT COUNT(1) as buanquanshu FROM T_Call_OutAnswers WHERE F_CusTelID IN (select F_CusTelID from T_Call_OutAnswers where F_OptOn between '" + startdate + "' and '" + enddate + "' and F_QID=102 and (F_QIID=101 OR F_QIID=102)) and F_QID=101 and F_QIID=" + ItemID);
  1245. if (obj0 != null && obj0.ToString() != "")
  1246. {
  1247. unsafenum = Convert.ToInt32(obj0);
  1248. }
  1249. buanquanleiji += unsafenum;
  1250. dr["buanquan"] = unsafenum;
  1251. //根据乡镇获取总数
  1252. int totalnum = 0;
  1253. object obj1 = DbHelperSQL.GetSingle("SELECT COUNT(*) from T_Call_OutAnswers where F_OptOn between '" + startdate + "' and '" + enddate + "' and F_QID=101 and F_QIID=" + ItemID + "");
  1254. if (obj1 != null && obj1.ToString() != "")
  1255. {
  1256. totalnum = Convert.ToInt32(obj1);
  1257. }
  1258. leiji += totalnum;
  1259. dr["zongshu"] = totalnum;
  1260. //计算比例
  1261. if (totalnum > 0)
  1262. {
  1263. decimal per = Math.Round(Convert.ToDecimal(Convert.ToDecimal(totalnum - unsafenum) / totalnum * 100), 1);
  1264. dr["zhishu"] = per;
  1265. }
  1266. else
  1267. { dr["zhishu"] = 0; }
  1268. dtnew.Rows.Add(dr);
  1269. }
  1270. }
  1271. dtnew.DefaultView.Sort = "zhishu DESC";
  1272. DataTable dtTemp = dtnew.DefaultView.ToTable();
  1273. //计算总计
  1274. DataRow dr0 = dtTemp.NewRow();
  1275. dr0["xiangzhen"] = "总计";
  1276. dr0["zongshu"] = leiji;
  1277. dr0["buanquan"] = buanquanleiji;
  1278. if (leiji > 0)
  1279. {
  1280. decimal per = Math.Round(Convert.ToDecimal(Convert.ToDecimal(leiji - buanquanleiji) / leiji * 100), 1);
  1281. dr0["zhishu"] = per;
  1282. }
  1283. else
  1284. { dr0["zhishu"] = 0; }
  1285. dtTemp.Rows.Add(dr0);
  1286. res = Success("获取乡镇报表数据成功", dtTemp);
  1287. return res;
  1288. }
  1289. #endregion
  1290. #region 数据查询--获取不安全详细信息
  1291. public ActionResult GetUnsafeInfo()
  1292. {
  1293. ActionResult res = NoToken("未知错误,请重新登录");
  1294. string startdate = HttpUtility.UrlDecode(RequestString.GetQueryString("startdate")) + " 00:00:00";
  1295. string enddate = HttpUtility.UrlDecode(RequestString.GetQueryString("enddate")) + " 23:59:59";
  1296. if (HttpUtility.UrlDecode(RequestString.GetQueryString("startdate")) == null || HttpUtility.UrlDecode(RequestString.GetQueryString("startdate")) == "")
  1297. {
  1298. startdate = DateTime.Now.ToString("yyyy-MM-dd") + " 00:00:00";
  1299. //enddate = DateTime.Now.ToString("yyyy-MM-dd") + " 23:59:59";
  1300. }
  1301. if (HttpUtility.UrlDecode(RequestString.GetQueryString("enddate")) == null || HttpUtility.UrlDecode(RequestString.GetQueryString("enddate")) == "")
  1302. {
  1303. //startdate = DateTime.Now.ToString("yyyy-MM-dd") + " 00:00:00";
  1304. enddate = DateTime.Now.ToString("yyyy-MM-dd") + " 23:59:59";
  1305. }
  1306. //startdate = "2017-11-12 00:00:00";
  1307. //enddate = "2017-11-14 23:59:59";
  1308. DataTable dtnew = new DataTable();
  1309. dtnew.Columns.Add("xiangzhen", Type.GetType("System.String"));
  1310. dtnew.Columns.Add("dianhua", Type.GetType("System.String"));
  1311. dtnew.Columns.Add("zhiye", Type.GetType("System.String"));
  1312. dtnew.Columns.Add("yuanyin", Type.GetType("System.String"));
  1313. //List<Model.T_Ask_Question> qrlist = new List<Model.T_Ask_Question>();
  1314. //DataSet ds = DbHelperSQL.Query("SELECT * FROM T_Ask_QuestionItems WHERE F_ItemId IN (SELECT F_QIID FROM T_Call_OutAnswers WHERE F_CusTelID IN (select F_CusTelID from T_Call_OutAnswers where F_OptOn between '" + startdate + "' and '" + enddate + "' and F_QID=102 and (F_QIID=101 OR F_QIID=102)) and F_QID=101 group by F_QIID)");
  1315. DataSet ds = DbHelperSQL.Query("select F_CusTelID,F_TaskID from T_Call_OutAnswers where F_OptOn between '" + startdate + "' and '" + enddate + "' and F_QID=102 and (F_QIID=101 OR F_QIID=102)");
  1316. if (ds != null && ds.Tables.Count > 0)
  1317. {
  1318. DataTable dt = ds.Tables[0];
  1319. for (int i = 0; i < dt.Rows.Count; i++)
  1320. {
  1321. DataRow dr = dtnew.NewRow();
  1322. string taskid = dt.Rows[i]["F_TaskID"].ToString();
  1323. string custelid = dt.Rows[i]["F_CusTelID"].ToString();
  1324. //获取乡镇
  1325. string xiangzhen = "";
  1326. object obj0 = DbHelperSQL.GetSingle("SELECT F_Answer FROM T_Call_OutAnswers WHERE F_CusTelID ='" + custelid + "' and F_TaskID='" + taskid + "' and F_QID=101");
  1327. if (obj0 != null)
  1328. {
  1329. xiangzhen = obj0.ToString();
  1330. }
  1331. dr["xiangzhen"] = xiangzhen;
  1332. //获取电话
  1333. string dianhua = "";
  1334. object obj2 = DbHelperSQL.GetSingle("SELECT F_Phone FROM T_Call_OutTaskTelNum WHERE F_Id ='" + custelid + "' and F_TaskID='" + taskid + "' ");
  1335. if (obj2 != null)
  1336. {
  1337. dianhua = obj2.ToString();
  1338. }
  1339. dr["dianhua"] = dianhua;
  1340. //获取职业
  1341. string zhiye = "";
  1342. object obj1 = DbHelperSQL.GetSingle("SELECT F_Answer FROM T_Call_OutAnswers WHERE F_CusTelID ='" + custelid + "' and F_TaskID='" + taskid + "' and F_QID=100");
  1343. if (obj1 != null)
  1344. {
  1345. zhiye = obj1.ToString();
  1346. }
  1347. dr["zhiye"] = zhiye;
  1348. //获取原因
  1349. string yuanyin = "";
  1350. object obj3 = DbHelperSQL.GetSingle("SELECT F_Answer FROM T_Call_OutAnswers WHERE F_CusTelID ='" + custelid + "' and F_TaskID='" + taskid + "' and F_QID=108");
  1351. if (obj3 != null)
  1352. {
  1353. yuanyin = obj3.ToString();
  1354. }
  1355. dr["yuanyin"] = yuanyin;
  1356. dtnew.Rows.Add(dr);
  1357. }
  1358. }
  1359. dtnew.DefaultView.Sort = "xiangzhen ASC";
  1360. DataTable dtTemp = dtnew.DefaultView.ToTable();
  1361. res = Success("获取不安全信息统计数据成功", dtTemp);
  1362. return res;
  1363. }
  1364. #endregion
  1365. #region 数据查询--获取不安全因素比例
  1366. public ActionResult GetUnsafeRate()
  1367. {
  1368. DataTable dtnew = GetData();
  1369. return Success("获取不安全原因比例报表数据成功", dtnew);
  1370. }
  1371. public ActionResult GetUnsafeRateExpt()
  1372. {
  1373. DataTable dtnew = GetData();
  1374. NPOIHelper npoi = new NPOIHelper();
  1375. string[] col = { "不安全原因", "数量", "比例" };
  1376. if (npoi.ExportToExcel("乡镇排名统计数据", dtnew, col) == "")
  1377. {
  1378. return Success("导出成功");
  1379. }
  1380. else
  1381. {
  1382. return Error("导出失败");
  1383. }
  1384. }
  1385. private DataTable GetData()
  1386. {
  1387. string startdate = HttpUtility.UrlDecode(RequestString.GetQueryString("startdate")) + " 00:00:00";
  1388. string enddate = HttpUtility.UrlDecode(RequestString.GetQueryString("enddate")) + " 23:59:59";
  1389. if (HttpUtility.UrlDecode(RequestString.GetQueryString("startdate")) == null || HttpUtility.UrlDecode(RequestString.GetQueryString("startdate")) == "")
  1390. {
  1391. startdate = DateTime.Now.ToString("yyyy-MM-dd") + " 00:00:00";
  1392. }
  1393. if (HttpUtility.UrlDecode(RequestString.GetQueryString("enddate")) == null || HttpUtility.UrlDecode(RequestString.GetQueryString("enddate")) == "")
  1394. {
  1395. enddate = DateTime.Now.ToString("yyyy-MM-dd") + " 23:59:59";
  1396. }
  1397. DataTable dtnew = new DataTable();
  1398. dtnew.Columns.Add("Reasons", Type.GetType("System.String"));
  1399. dtnew.Columns.Add("Counts", Type.GetType("System.String"));
  1400. dtnew.Columns.Add("Rates", Type.GetType("System.String"));
  1401. int sumcount = 0;
  1402. DataSet ds = DbHelperSQL.Query("SELECT * FROM T_Ask_QuestionItems where F_QuestionId='103'");
  1403. DataSet dsc = DbHelperSQL.Query("select F_QIID,COUNT(*) c from T_Call_OutAnswers where F_OptOn between '" + startdate + "' and '" + enddate + "' and F_QID=103 group by F_QIID");
  1404. if (ds != null && ds.Tables.Count > 0)
  1405. {
  1406. DataTable dt = ds.Tables[0];
  1407. for (int i = 0; i < dt.Rows.Count; i++)
  1408. {
  1409. DataRow dr = dtnew.NewRow();
  1410. string content = dt.Rows[i]["F_ItemName"].ToString();
  1411. string ItemID = dt.Rows[i]["F_ItemID"].ToString();
  1412. dr["Reasons"] = content;
  1413. int count = 0;
  1414. if (dsc != null && dsc.Tables.Count > 0)
  1415. {
  1416. DataTable dtc = dsc.Tables[0];
  1417. for (int j = 0; j < dtc.Rows.Count; j++)
  1418. {
  1419. if (dtc.Rows[j]["F_QIID"].ToString().Equals(dt.Rows[i]["F_ItemID"].ToString()))
  1420. {
  1421. count = int.Parse(dtc.Rows[j]["c"].ToString());
  1422. sumcount += count;
  1423. break;
  1424. }
  1425. }
  1426. }
  1427. dr["Counts"] = count;
  1428. dr["Rates"] = 0;
  1429. dtnew.Rows.Add(dr);
  1430. }
  1431. for (int z = 0; z < dtnew.Rows.Count; z++)
  1432. {
  1433. int count = 0;
  1434. count = int.Parse(dtnew.Rows[z]["Counts"].ToString());
  1435. if (sumcount > 0)
  1436. {
  1437. decimal perww = Math.Round(Convert.ToDecimal(Convert.ToDecimal(count) / sumcount * 100), 1);
  1438. dtnew.Rows[z]["Rates"] = perww;
  1439. }
  1440. }
  1441. }
  1442. return dtnew;
  1443. }
  1444. #endregion
  1445. #region 导出
  1446. #region 数据查询--获取排名
  1447. public ActionResult GetRankExpt()
  1448. {
  1449. ActionResult res = NoToken("未知错误,请重新登录");
  1450. string startdate = HttpUtility.UrlDecode(RequestString.GetQueryString("startdate")) + " 00:00:00";
  1451. string enddate = HttpUtility.UrlDecode(RequestString.GetQueryString("enddate")) + " 23:59:59";
  1452. if (HttpUtility.UrlDecode(RequestString.GetQueryString("startdate")) == null || HttpUtility.UrlDecode(RequestString.GetQueryString("startdate")) == "")
  1453. {
  1454. startdate = DateTime.Now.ToString("yyyy-MM-dd") + " 00:00:00";
  1455. //enddate = DateTime.Now.ToString("yyyy-MM-dd") + " 23:59:59";
  1456. }
  1457. if (HttpUtility.UrlDecode(RequestString.GetQueryString("enddate")) == null || HttpUtility.UrlDecode(RequestString.GetQueryString("enddate")) == "")
  1458. {
  1459. //startdate = DateTime.Now.ToString("yyyy-MM-dd") + " 00:00:00";
  1460. enddate = DateTime.Now.ToString("yyyy-MM-dd") + " 23:59:59";
  1461. }
  1462. //startdate = "2017-11-12 00:00:00";
  1463. //enddate = "2017-11-14 23:59:59";
  1464. DataTable dtnew = new DataTable();
  1465. dtnew.Columns.Add("paiming", Type.GetType("System.String"));
  1466. dtnew.Columns.Add("xiangzhen", Type.GetType("System.String"));
  1467. dtnew.Columns.Add("zongshu", Type.GetType("System.Int32"));
  1468. dtnew.Columns.Add("buanquan", Type.GetType("System.Int32"));
  1469. dtnew.Columns.Add("zhishu", Type.GetType("System.Decimal"));
  1470. int leiji = 0;
  1471. int buanquanleiji = 0;
  1472. //List<Model.T_Ask_Question> qrlist = new List<Model.T_Ask_Question>();
  1473. //DataSet ds = DbHelperSQL.Query("SELECT * FROM T_Ask_QuestionItems WHERE F_ItemId IN (SELECT F_QIID FROM T_Call_OutAnswers WHERE F_CusTelID IN (select F_CusTelID from T_Call_OutAnswers where F_OptOn between '" + startdate + "' and '" + enddate + "' and F_QID=102 ) and F_QID=101 group by F_QIID)");//and (F_QIID=101 OR F_QIID=102)
  1474. DataSet ds = DbHelperSQL.Query("SELECT * FROM T_Ask_QuestionItems where F_QuestionId='101'");
  1475. if (ds != null && ds.Tables.Count > 0)
  1476. {
  1477. DataTable dt = ds.Tables[0];
  1478. for (int i = 0; i < dt.Rows.Count; i++)
  1479. {
  1480. DataRow dr = dtnew.NewRow();
  1481. string content = dt.Rows[i]["F_ItemName"].ToString();
  1482. string ItemID = dt.Rows[i]["F_ItemID"].ToString();
  1483. dr["xiangzhen"] = content;
  1484. //根据乡镇获取不安全数
  1485. int unsafenum = 0;
  1486. object obj0 = DbHelperSQL.GetSingle("SELECT COUNT(1) as buanquanshu FROM T_Call_OutAnswers WHERE F_CusTelID IN (select F_CusTelID from T_Call_OutAnswers where F_OptOn between '" + startdate + "' and '" + enddate + "' and F_QID=102 and (F_QIID=101 OR F_QIID=102)) and F_QID=101 and F_QIID=" + ItemID);
  1487. if (obj0 != null && obj0.ToString() != "")
  1488. {
  1489. unsafenum = Convert.ToInt32(obj0);
  1490. }
  1491. buanquanleiji += unsafenum;
  1492. dr["buanquan"] = unsafenum;
  1493. //根据乡镇获取总数
  1494. int totalnum = 0;
  1495. object obj1 = DbHelperSQL.GetSingle("SELECT COUNT(*) from T_Call_OutAnswers where F_OptOn between '" + startdate + "' and '" + enddate + "' and F_QID=101 and F_QIID=" + ItemID + "");
  1496. if (obj1 != null && obj1.ToString() != "")
  1497. {
  1498. totalnum = Convert.ToInt32(obj1);
  1499. }
  1500. dr["zongshu"] = totalnum;
  1501. leiji += totalnum;
  1502. //计算比例
  1503. if (totalnum > 0)
  1504. {
  1505. decimal per = Math.Round(Convert.ToDecimal(Convert.ToDecimal(totalnum - unsafenum) / totalnum * 100), 1);
  1506. dr["zhishu"] = per;
  1507. }
  1508. else
  1509. { dr["zhishu"] = 0; }
  1510. dtnew.Rows.Add(dr);
  1511. }
  1512. }
  1513. dtnew.DefaultView.Sort = "zhishu DESC";
  1514. DataTable dtTemp = dtnew.DefaultView.ToTable();
  1515. for (int h = 0; h < dtTemp.Rows.Count; h++)
  1516. {
  1517. dtTemp.Rows[h]["paiming"] = h + 1;
  1518. }
  1519. //计算总计
  1520. DataRow dr0 = dtTemp.NewRow();
  1521. dr0["paiming"] = "";
  1522. dr0["xiangzhen"] = "总计";
  1523. dr0["zongshu"] = leiji;
  1524. dr0["buanquan"] = buanquanleiji;
  1525. if (leiji > 0)
  1526. {
  1527. decimal per = Math.Round(Convert.ToDecimal(Convert.ToDecimal(leiji - buanquanleiji) / leiji * 100), 1);
  1528. dr0["zhishu"] = per;
  1529. }
  1530. else
  1531. { dr0["zhishu"] = 0; }
  1532. dtTemp.Rows.Add(dr0);
  1533. //res = Success("获取乡镇报表数据成功", dtTemp);
  1534. //return res;
  1535. //导出dtnew
  1536. NPOIHelper npoi = new NPOIHelper();
  1537. string[] col = { "排名", "乡镇", "总数", "不安全", "指数" };
  1538. if (npoi.ExportToExcel("乡镇排名统计数据", dtTemp, col) == "")
  1539. {
  1540. return Success("导出成功");
  1541. }
  1542. else
  1543. {
  1544. return Error("导出失败");
  1545. }
  1546. }
  1547. #endregion
  1548. #region 数据查询--获取不安全详细信息
  1549. public ActionResult GetUnsafeInfoExpt()
  1550. {
  1551. ActionResult res = NoToken("未知错误,请重新登录");
  1552. string startdate = HttpUtility.UrlDecode(RequestString.GetQueryString("startdate")) + " 00:00:00";
  1553. string enddate = HttpUtility.UrlDecode(RequestString.GetQueryString("enddate")) + " 23:59:59";
  1554. if (HttpUtility.UrlDecode(RequestString.GetQueryString("startdate")) == null || HttpUtility.UrlDecode(RequestString.GetQueryString("startdate")) == "")
  1555. {
  1556. startdate = DateTime.Now.ToString("yyyy-MM-dd") + " 00:00:00";
  1557. //enddate = DateTime.Now.ToString("yyyy-MM-dd") + " 23:59:59";
  1558. }
  1559. if (HttpUtility.UrlDecode(RequestString.GetQueryString("enddate")) == null || HttpUtility.UrlDecode(RequestString.GetQueryString("enddate")) == "")
  1560. {
  1561. //startdate = DateTime.Now.ToString("yyyy-MM-dd") + " 00:00:00";
  1562. enddate = DateTime.Now.ToString("yyyy-MM-dd") + " 23:59:59";
  1563. }
  1564. //startdate = "2017-11-12 00:00:00";
  1565. //enddate = "2017-11-14 23:59:59";
  1566. DataTable dtnew = new DataTable();
  1567. dtnew.Columns.Add("xiangzhen", Type.GetType("System.String"));
  1568. dtnew.Columns.Add("dianhua", Type.GetType("System.String"));
  1569. dtnew.Columns.Add("zhiye", Type.GetType("System.String"));
  1570. dtnew.Columns.Add("yuanyin", Type.GetType("System.String"));
  1571. //List<Model.T_Ask_Question> qrlist = new List<Model.T_Ask_Question>();
  1572. //DataSet ds = DbHelperSQL.Query("SELECT * FROM T_Ask_QuestionItems WHERE F_ItemId IN (SELECT F_QIID FROM T_Call_OutAnswers WHERE F_CusTelID IN (select F_CusTelID from T_Call_OutAnswers where F_OptOn between '" + startdate + "' and '" + enddate + "' and F_QID=102 and (F_QIID=101 OR F_QIID=102)) and F_QID=101 group by F_QIID)");
  1573. DataSet ds = DbHelperSQL.Query("select F_CusTelID,F_TaskID from T_Call_OutAnswers where F_OptOn between '" + startdate + "' and '" + enddate + "' and F_QID=102 and (F_QIID=101 OR F_QIID=102)");
  1574. if (ds != null && ds.Tables.Count > 0)
  1575. {
  1576. DataTable dt = ds.Tables[0];
  1577. if (dt.Rows.Count > 0)
  1578. {
  1579. //return Success("当前日期没有可导出的数据");
  1580. for (int i = 0; i < dt.Rows.Count; i++)
  1581. {
  1582. DataRow dr = dtnew.NewRow();
  1583. string taskid = dt.Rows[i]["F_TaskID"].ToString();
  1584. string custelid = dt.Rows[i]["F_CusTelID"].ToString();
  1585. //获取乡镇
  1586. string xiangzhen = "";
  1587. object obj0 = DbHelperSQL.GetSingle("SELECT F_Answer FROM T_Call_OutAnswers WHERE F_CusTelID ='" + custelid + "' and F_TaskID='" + taskid + "' and F_QID=101");
  1588. if (obj0 != null)
  1589. {
  1590. xiangzhen = obj0.ToString();
  1591. }
  1592. dr["xiangzhen"] = xiangzhen;
  1593. //获取电话
  1594. string dianhua = "";
  1595. object obj2 = DbHelperSQL.GetSingle("SELECT F_Phone FROM T_Call_OutTaskTelNum WHERE F_Id ='" + custelid + "' and F_TaskID='" + taskid + "' ");
  1596. if (obj2 != null)
  1597. {
  1598. dianhua = obj2.ToString();
  1599. }
  1600. dr["dianhua"] = dianhua;
  1601. //获取职业
  1602. string zhiye = "";
  1603. object obj1 = DbHelperSQL.GetSingle("SELECT F_Answer FROM T_Call_OutAnswers WHERE F_CusTelID ='" + custelid + "' and F_TaskID='" + taskid + "' and F_QID=100");
  1604. if (obj1 != null)
  1605. {
  1606. zhiye = obj1.ToString();
  1607. }
  1608. dr["zhiye"] = zhiye;
  1609. //获取原因
  1610. string yuanyin = "";
  1611. object obj3 = DbHelperSQL.GetSingle("SELECT F_Answer FROM T_Call_OutAnswers WHERE F_CusTelID ='" + custelid + "' and F_TaskID='" + taskid + "' and F_QID=108");
  1612. if (obj3 != null)
  1613. {
  1614. yuanyin = obj3.ToString();
  1615. }
  1616. dr["yuanyin"] = yuanyin;
  1617. dtnew.Rows.Add(dr);
  1618. }
  1619. }
  1620. }
  1621. dtnew.DefaultView.Sort = "xiangzhen ASC";
  1622. DataTable dtTemp = dtnew.DefaultView.ToTable();
  1623. //res = Success("获取不安全信息统计数据成功", dtTemp);
  1624. //return res;
  1625. //导出dtnew
  1626. NPOIHelper npoi = new NPOIHelper();
  1627. string[] col = { "乡(镇、街道)", "机主电话", "职业", "原因" };
  1628. if (npoi.ExportToExcel("不安全信息统计数据", dtTemp, col) == "")
  1629. {
  1630. return Success("导出成功");
  1631. }
  1632. else
  1633. {
  1634. return Error("导出失败");
  1635. }
  1636. }
  1637. #endregion
  1638. #endregion
  1639. //病人信息管理里的随访,参数是taskid,病人id
  1640. //患者随访完成中 填写的问卷答案
  1641. public ActionResult GetQuestionAnswerDetailByTask(int id,int taskid)
  1642. {
  1643. DataTable dt = DbHelperSQL.Query($" SELECT F_QID, F_CusTelID, (SELECT F_Title FROM T_Ask_PagerInfo WHERE F_PagerId = (SELECT F_PagerId FROM T_Ask_PagerItems WHERE F_QuestionId = F_QID)) AS Name, F_Answer, F_Title, F_TaskID FROM sf_taskAnswers a LEFT JOIN T_Ask_Question b ON a.F_QID = b.F_QuestionId WHERE a.F_TaskID ="+taskid+" and a.F_CusTelID =" + id + "").Tables[0];
  1644. List<returnmodel> list = new List<returnmodel>();
  1645. foreach (DataRow item in dt.Rows)
  1646. {
  1647. returnmodel rmodel = new returnmodel();
  1648. rmodel.QuestionTitle = item["F_Title"]?.ToString();
  1649. rmodel.Answer = item["F_Answer"]?.ToString();
  1650. rmodel.Name = item["Name"]?.ToString();
  1651. list.Add(rmodel);
  1652. }
  1653. return Success("获取问卷信息成功", list);
  1654. }
  1655. }
  1656. public class returnmodel
  1657. {
  1658. public string QuestionTitle { get; set; }
  1659. public string Answer { get; set; }
  1660. public string Name { get; set; }
  1661. }
  1662. }