PingAnYeXianSZCG_API 接口代码

QuestionnaireController.cs 76KB

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