You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

StudentCertificateService.cs 10 KiB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309
  1. using Dapper;
  2. using Learun.DataBase.Repository;
  3. using Learun.Util;
  4. using System;
  5. using System.Collections.Generic;
  6. using System.Data;
  7. using System.Text;
  8. namespace Learun.Application.TwoDevelopment.EducationalAdministration
  9. {
  10. /// <summary>
  11. /// 版 本 Learun-ADMS V7.0.6 力软敏捷开发框架
  12. /// Copyright (c) 2013-2020 力软信息技术(苏州)有限公司
  13. /// 创 建:超级管理员
  14. /// 日 期:2022-08-30 11:05
  15. /// 描 述:学生证书管理
  16. /// </summary>
  17. public class StudentCertificateService : RepositoryFactory
  18. {
  19. #region 获取数据
  20. /// <summary>
  21. /// 获取页面显示列表数据
  22. /// </summary>
  23. /// <param name="pagination">分页参数</param>
  24. /// <param name="queryJson">查询参数</param>
  25. /// <returns></returns>
  26. public IEnumerable<StudentCertificateEntity> GetPageList(Pagination pagination, string queryJson)
  27. {
  28. try
  29. {
  30. var strSql = new StringBuilder();
  31. strSql.Append("SELECT ");
  32. strSql.Append(@"
  33. t.*
  34. ");
  35. strSql.Append(" FROM StudentCertificate t ");
  36. strSql.Append(" WHERE 1=1 ");
  37. var queryParam = queryJson.ToJObject();
  38. // 虚拟参数
  39. var dp = new DynamicParameters(new { });
  40. if (!queryParam["AcademicYearNo"].IsEmpty())
  41. {
  42. dp.Add("AcademicYearNo", queryParam["AcademicYearNo"].ToString(), DbType.String);
  43. strSql.Append(" AND t.AcademicYearNo = @AcademicYearNo ");
  44. }
  45. if (!queryParam["Semester"].IsEmpty())
  46. {
  47. dp.Add("Semester", queryParam["Semester"].ToString(), DbType.String);
  48. strSql.Append(" AND t.Semester = @Semester ");
  49. }
  50. if (!queryParam["StuNo"].IsEmpty())
  51. {
  52. dp.Add("StuNo", "%" + queryParam["StuNo"].ToString() + "%", DbType.String);
  53. strSql.Append(" AND t.StuNo Like @StuNo ");
  54. }
  55. if (!queryParam["StuName"].IsEmpty())
  56. {
  57. dp.Add("StuName", "%" + queryParam["StuName"].ToString() + "%", DbType.String);
  58. strSql.Append(" AND t.StuName Like @StuName ");
  59. }
  60. if (!queryParam["DeptNo"].IsEmpty())
  61. {
  62. dp.Add("DeptNo", queryParam["DeptNo"].ToString(), DbType.String);
  63. strSql.Append(" AND t.DeptNo = @DeptNo ");
  64. }
  65. if (!queryParam["MajorNo"].IsEmpty())
  66. {
  67. dp.Add("MajorNo", queryParam["MajorNo"].ToString(), DbType.String);
  68. strSql.Append(" AND t.MajorNo = @MajorNo ");
  69. }
  70. if (!queryParam["ClassNo"].IsEmpty())
  71. {
  72. dp.Add("ClassNo", queryParam["ClassNo"].ToString(), DbType.String);
  73. strSql.Append(" AND t.ClassNo = @ClassNo ");
  74. }
  75. if (!queryParam["SCName"].IsEmpty())
  76. {
  77. dp.Add("SCName", "%" + queryParam["SCName"].ToString() + "%", DbType.String);
  78. strSql.Append(" AND t.SCName Like @SCName ");
  79. }
  80. if (!queryParam["SCLevel"].IsEmpty())
  81. {
  82. dp.Add("SCLevel", "%" + queryParam["SCLevel"].ToString() + "%", DbType.String);
  83. strSql.Append(" AND t.SCLevel Like @SCLevel ");
  84. }
  85. if (!queryParam["SCTime"].IsEmpty())
  86. {
  87. dp.Add("SCTime", queryParam["SCTime"].ToString(), DbType.String);
  88. strSql.Append(" AND t.SCTime = @SCTime ");
  89. }
  90. return this.BaseRepository("CollegeMIS").FindList<StudentCertificateEntity>(strSql.ToString(), dp, pagination);
  91. }
  92. catch (Exception ex)
  93. {
  94. if (ex is ExceptionEx)
  95. {
  96. throw;
  97. }
  98. else
  99. {
  100. throw ExceptionEx.ThrowServiceException(ex);
  101. }
  102. }
  103. }
  104. /// <summary>
  105. /// 获取StudentCertificate表实体数据
  106. /// </summary>
  107. /// <param name="keyValue">主键</param>
  108. /// <returns></returns>
  109. public StudentCertificateEntity GetStudentCertificateEntity(string keyValue)
  110. {
  111. try
  112. {
  113. return this.BaseRepository("CollegeMIS").FindEntity<StudentCertificateEntity>(keyValue);
  114. }
  115. catch (Exception ex)
  116. {
  117. if (ex is ExceptionEx)
  118. {
  119. throw;
  120. }
  121. else
  122. {
  123. throw ExceptionEx.ThrowServiceException(ex);
  124. }
  125. }
  126. }
  127. /// <summary>
  128. /// 获取主表实体数据
  129. /// </summary>
  130. /// <param name="processId">流程实例ID</param>
  131. /// <returns></returns>
  132. public StudentCertificateEntity GetEntityByProcessId(string processId)
  133. {
  134. try
  135. {
  136. return this.BaseRepository("CollegeMIS").FindEntity<StudentCertificateEntity>(t => t.processId == processId);
  137. }
  138. catch (Exception ex)
  139. {
  140. if (ex is ExceptionEx)
  141. {
  142. throw;
  143. }
  144. else
  145. {
  146. throw ExceptionEx.ThrowServiceException(ex);
  147. }
  148. }
  149. }
  150. /// <summary>
  151. /// 获取页面显示列表数据
  152. /// </summary>
  153. /// <returns></returns>
  154. public IEnumerable<StudentCertificateEntity> GetList(string queryJson)
  155. {
  156. try
  157. {
  158. var strSql = new StringBuilder();
  159. strSql.Append("SELECT t.* ");
  160. strSql.Append(" FROM StudentCertificate t ");
  161. strSql.Append(" WHERE 1=1 and t.Status=2 ");
  162. var queryParam = queryJson.ToJObject();
  163. // 虚拟参数
  164. var dp = new DynamicParameters(new { });
  165. if (!queryParam["StuNo"].IsEmpty())
  166. {
  167. dp.Add("StuNo", queryParam["StuNo"].ToString(), DbType.String);
  168. strSql.Append(" AND t.StuNo = @StuNo ");
  169. }
  170. if (!queryParam["StuName"].IsEmpty())
  171. {
  172. dp.Add("StuName", "%" + queryParam["StuName"].ToString() + "%", DbType.String);
  173. strSql.Append(" AND t.StuName Like @StuName ");
  174. }
  175. if (!queryParam["AcademicYearNo"].IsEmpty())
  176. {
  177. dp.Add("AcademicYearNo", queryParam["AcademicYearNo"].ToString(), DbType.String);
  178. strSql.Append(" AND t.AcademicYearNo = @AcademicYearNo ");
  179. }
  180. if (!queryParam["Semester"].IsEmpty())
  181. {
  182. dp.Add("Semester", queryParam["Semester"].ToString(), DbType.String);
  183. strSql.Append(" AND t.Semester = @Semester ");
  184. }
  185. return this.BaseRepository("CollegeMIS").FindList<StudentCertificateEntity>(strSql.ToString(), dp);
  186. }
  187. catch (Exception ex)
  188. {
  189. if (ex is ExceptionEx)
  190. {
  191. throw;
  192. }
  193. else
  194. {
  195. throw ExceptionEx.ThrowServiceException(ex);
  196. }
  197. }
  198. }
  199. #endregion
  200. #region 提交数据
  201. /// <summary>
  202. /// 删除实体数据
  203. /// </summary>
  204. /// <param name="keyValue">主键</param>
  205. public void DeleteEntity(string keyValue)
  206. {
  207. try
  208. {
  209. this.BaseRepository("CollegeMIS").Delete<StudentCertificateEntity>(t => t.Id == keyValue);
  210. }
  211. catch (Exception ex)
  212. {
  213. if (ex is ExceptionEx)
  214. {
  215. throw;
  216. }
  217. else
  218. {
  219. throw ExceptionEx.ThrowServiceException(ex);
  220. }
  221. }
  222. }
  223. /// <summary>
  224. /// 保存实体数据(新增、修改)
  225. /// </summary>
  226. /// <param name="keyValue">主键</param>
  227. /// <param name="entity">实体</param>
  228. /// <returns></returns>
  229. public void SaveEntity(string keyValue, StudentCertificateEntity entity)
  230. {
  231. try
  232. {
  233. if (!string.IsNullOrEmpty(keyValue))
  234. {
  235. entity.Modify(keyValue);
  236. this.BaseRepository("CollegeMIS").Update(entity);
  237. }
  238. else
  239. {
  240. entity.Create();
  241. this.BaseRepository("CollegeMIS").Insert(entity);
  242. }
  243. }
  244. catch (Exception ex)
  245. {
  246. if (ex is ExceptionEx)
  247. {
  248. throw;
  249. }
  250. else
  251. {
  252. throw ExceptionEx.ThrowServiceException(ex);
  253. }
  254. }
  255. }
  256. public void ChangeStatusByProcessId(string processId, int status)
  257. {
  258. try
  259. {
  260. this.BaseRepository("CollegeMIS").ExecuteBySql($"update StudentCertificate set Status='{status}' where processId='{processId}'");
  261. }
  262. catch (Exception ex)
  263. {
  264. if (ex is ExceptionEx)
  265. {
  266. throw;
  267. }
  268. else
  269. {
  270. throw ExceptionEx.ThrowServiceException(ex);
  271. }
  272. }
  273. }
  274. public void ChangeStatusById(string keyValue, int status, string processId)
  275. {
  276. try
  277. {
  278. this.BaseRepository("CollegeMIS").ExecuteBySql($"update StudentCertificate set Status='{status}',processId='{processId}' where Id='{keyValue}'");
  279. }
  280. catch (Exception ex)
  281. {
  282. if (ex is ExceptionEx)
  283. {
  284. throw;
  285. }
  286. else
  287. {
  288. throw ExceptionEx.ThrowServiceException(ex);
  289. }
  290. }
  291. }
  292. #endregion
  293. }
  294. }