CFormColumnManager.cs 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.Threading.Tasks;
  6. using System.Data;
  7. namespace PMSUI
  8. {
  9. public class CFormColumnManager
  10. {
  11. /// <summary>
  12. /// 根据列显示设置,获取DataGridview的数据
  13. /// </summary>
  14. /// <param name="formName">界面名字,要和数据库事先输入的一致</param>
  15. /// <param name="SqlTableName">实际数据从哪个表获取</param>
  16. /// <param name="strOrderby">如果需要排序,格式例:order by CreateTime desc</param>
  17. /// <param name="strwhere">查询条件,格式例:Age < 30</param>
  18. /// <returns></returns>
  19. public static DataTable GetDGVDataSource(string formName, string SqlTableName, string strOrderby = "", string strwhere = "")
  20. {
  21. string temp = "FormName ='" + formName + "' and IsShow = 1 order by Sort";
  22. List<PmsCoreDB.Model.PMS_sys_FormColumnSetting> columnModelList = PmsCoreDB.DBHost.Instance.ColumnSetting.GetModelList(temp);
  23. string SqlQueryString = "Select ";
  24. for (int i = 0; i < columnModelList.Count; i++)
  25. {
  26. if (i == 0)
  27. {
  28. SqlQueryString += columnModelList[i].DBColumnName + " as [" + CLanguageManager.LanguageChange(columnModelList[i].ShowColumnName) + "]";
  29. //SqlQueryString += columnModelList[i].DBColumnName + " as " + columnModelList[i].ShowColumnName;
  30. }
  31. else
  32. {
  33. SqlQueryString += ("," + columnModelList[i].DBColumnName + " as [" + CLanguageManager.LanguageChange(columnModelList[i].ShowColumnName) + "]");
  34. //SqlQueryString += ("," + columnModelList[i].DBColumnName + " as " + columnModelList[i].ShowColumnName);
  35. }
  36. }
  37. SqlQueryString += " from " + SqlTableName;
  38. if (strwhere != "")
  39. {
  40. SqlQueryString += " where " + strwhere;
  41. }
  42. if (strOrderby != "")
  43. {
  44. SqlQueryString += " "+ strOrderby;
  45. }
  46. return PmsCoreDB.DBHost.Instance.ColumnSetting.GetDataTableByString(SqlQueryString);
  47. }
  48. /// <summary>
  49. /// 获取List<string> 用于初始化界面控件是否显示
  50. /// </summary>
  51. /// <param name="formName">界面名字,要和数据库事先输入的一致</param>
  52. /// <returns></returns>
  53. public static List<string> GetNeedShowDBList(string formName)
  54. {
  55. List<string> returnStringList = new List<string>();
  56. string strWhere = "FormName ='" + formName + "' and IsShow = 1 order by Sort";
  57. List<PmsCoreDB.Model.PMS_sys_FormColumnSetting> columnModelList = PmsCoreDB.DBHost.Instance.ColumnSetting.GetModelList(strWhere);
  58. foreach (PmsCoreDB.Model.PMS_sys_FormColumnSetting model in columnModelList)
  59. {
  60. returnStringList.Add(model.DBColumnName);
  61. }
  62. return returnStringList;
  63. }
  64. /// <summary>
  65. /// 获取字典 Key:数据库字段名,Value:显示名,用于在各界面初始化获取,用于datagridview CellMouseClick事件
  66. /// </summary>
  67. /// <param name="formName">界面名字,要和数据库事先输入的一致</param>
  68. /// <returns></returns>
  69. public static bool GetDBNameToShowNameDic(string formName,out Dictionary<string, string> returnDic)
  70. {
  71. returnDic = new Dictionary<string, string>();
  72. bool ret = false;
  73. string strWhere = "FormName ='" + formName + "' and IsShow = 1 order by Sort";
  74. List<PmsCoreDB.Model.PMS_sys_FormColumnSetting> columnModelList = PmsCoreDB.DBHost.Instance.ColumnSetting.GetModelList(strWhere);
  75. foreach (PmsCoreDB.Model.PMS_sys_FormColumnSetting model in columnModelList)
  76. {
  77. returnDic.Add(model.DBColumnName, CLanguageManager.LanguageChange(model.ShowColumnName));
  78. //returnDic.Add(model.DBColumnName, model.ShowColumnName);
  79. ret = true;
  80. }
  81. return ret;
  82. }
  83. /// <summary>
  84. ///
  85. /// </summary>
  86. /// <param name="formName">界面名字,要和数据库事先输入的一致</param>
  87. /// <returns></returns>
  88. public static bool GetAllFormNameToShowNameDic(out Dictionary<string, string> returnDic)
  89. {
  90. returnDic = new Dictionary<string, string>();
  91. bool ret = false;
  92. List<PmsCoreDB.Model.PMS_sys_MenuSetting> columnModelList = PmsCoreDB.DBHost.Instance.MenuSetting.GetModelList("");
  93. foreach (PmsCoreDB.Model.PMS_sys_MenuSetting model in columnModelList)
  94. {
  95. returnDic.Add(model.MenuName, CLanguageManager.LanguageChange(model.DisplayMenuName));
  96. ret = true;
  97. }
  98. return ret;
  99. }
  100. }
  101. }