GetUiConfigFormDB.cpp 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. #include "GetUiConfigFormDB.h"
  2. #include "Src/common/JLogAllOutput.h"
  3. bool GetMainUiConfigFormDB::checkDatabase()
  4. {
  5. QSqlDatabase db = QSqlDatabase::database();
  6. if (!db.isOpen())
  7. {
  8. JLogAllOutput::cmd_Warning("数据库未打开");
  9. return false;
  10. }
  11. return true;
  12. }
  13. QJsonObject GetMainUiConfigFormDB::getInfofromDb()
  14. {
  15. QJsonObject data;
  16. if (!checkDatabase())
  17. {
  18. return data;
  19. }
  20. QSqlQuery query;
  21. query.prepare("SELECT Function, Description, setValue FROM systemConfig");
  22. if (query.exec())
  23. {
  24. QJsonArray fieldsArray;
  25. while (query.next())
  26. {
  27. QJsonObject field;
  28. field["Function"] = query.value("Function").toString();
  29. field["Description"] = query.value("Description").toString();
  30. field["setValue"] = query.value("setValue").toInt();
  31. fieldsArray.append(field);
  32. }
  33. data["systemConfig"] = fieldsArray;
  34. }
  35. else
  36. {
  37. JLogAllOutput::cmd_Warning("查询 systemConfig 失败:" + query.lastError().text().toStdString());
  38. }
  39. return data;
  40. }
  41. int GetMainUiConfigFormDB::getConfigValue(const QString& function)
  42. {
  43. if (!checkDatabase())
  44. {
  45. return -1;
  46. }
  47. QSqlQuery query;
  48. query.prepare("SELECT setValue FROM systemConfig WHERE Function = :function");
  49. query.bindValue(":function", function);
  50. if (query.exec() && query.next())
  51. {
  52. return query.value("setValue").toInt();
  53. }
  54. JLogAllOutput::cmd_Warning("查询 systemConfig 失败:" + query.lastError().text().toStdString());
  55. return -1;
  56. }
  57. bool GetMainUiConfigFormDB::setConfigValue(const QString& function, int value)
  58. {
  59. if (!checkDatabase())
  60. {
  61. return false;
  62. }
  63. QSqlQuery query;
  64. query.prepare("UPDATE systemConfig SET setValue = :value WHERE Function = :function");
  65. query.bindValue(":value", value);
  66. query.bindValue(":function", function);
  67. if (query.exec())
  68. {
  69. JLogAllOutput::cmd_debug("Update successful");
  70. return true;
  71. }
  72. JLogAllOutput::cmd_debug("Update failed:" + query.lastError().text().toStdString());
  73. return false;
  74. }
  75. int GetMainUiConfigFormDB::getLanguageValue()
  76. {
  77. return getConfigValue("language");
  78. }
  79. int GetMainUiConfigFormDB::getThemeValue()
  80. {
  81. return getConfigValue("theme");
  82. }
  83. void GetMainUiConfigFormDB::setLanguageValue(int data)
  84. {
  85. setConfigValue("language", data);
  86. }
  87. void GetMainUiConfigFormDB::setThemeValue(int data)
  88. {
  89. setConfigValue("theme", data);
  90. }