EffectIndexInfoService.cpp 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. #include "EffectIndexInfoService.h"
  2. #include "SqlDBHelper.h"
  3. #include <QDebug>
  4. EffectIndexInfoService::EffectIndexInfoService(QObject *parent) { }
  5. int EffectIndexInfoService::AddEffectIndexInfo(const EffectIndexInfo &effectIndexInfo)
  6. {
  7. int ret = -1;
  8. try {
  9. Transaction t(SqlDBHelper::getDatabase());
  10. InsertQuery query = t.insertInto("t_effect_index_info(`project_id`, `effect_index_name`, `effect_index_value`, "
  11. "`effect_index_unit`, `extend_left`, `extend_right`)");
  12. NonQueryResult result = query.values(effectIndexInfo.projectId, effectIndexInfo.effectIndexName,
  13. effectIndexInfo.effectIndexValue, effectIndexInfo.effectIndexUnit,
  14. effectIndexInfo.extendLeft, effectIndexInfo.extendRight)
  15. .exec();
  16. t.commit();
  17. ret = result.lastInsertId().toInt();
  18. } catch (const DBException &ex) {
  19. qDebug() << ex.lastError.text();
  20. }
  21. return ret;
  22. }
  23. bool EffectIndexInfoService::QueryEffectIndexInfoByProjectId(EffectIndexInfo *effectIndexInfo, int projectId)
  24. {
  25. QSqlDatabase db = SqlDBHelper::getDatabase();
  26. QSqlQuery query(db);
  27. bool ret = false;
  28. QString selectSql =
  29. QString("SELECT id, "
  30. "project_id,effect_index_name,effect_index_value,effect_index_unit,extend_left,extend_right FROM "
  31. "t_effect_index_info WHERE project_id = %1")
  32. .arg(projectId);
  33. if (query.exec(selectSql)) {
  34. if (query.next()) {
  35. if (query.isNull(0) == false) {
  36. effectIndexInfo->id = query.value(0).toInt();
  37. effectIndexInfo->projectId = query.value(1).toInt();
  38. effectIndexInfo->effectIndexName = query.value(2).toString();
  39. effectIndexInfo->effectIndexValue = query.value(3).toString();
  40. effectIndexInfo->effectIndexUnit = query.value(4).toString();
  41. effectIndexInfo->extendLeft = query.value(5).toString();
  42. effectIndexInfo->extendRight = query.value(6).toString();
  43. }
  44. ret = true;
  45. }
  46. } else {
  47. qDebug() << query.lastError();
  48. }
  49. return ret;
  50. }
  51. bool EffectIndexInfoService::UpdateEffectIndexInfo(const EffectIndexInfo &effectIndexInfo)
  52. {
  53. bool ret = false;
  54. try {
  55. Transaction t(SqlDBHelper::getDatabase());
  56. t.update("t_effect_index_info")
  57. .set("effect_index_name", effectIndexInfo.effectIndexName)
  58. .set("effect_index_value", effectIndexInfo.effectIndexValue)
  59. .set("effect_index_unit", effectIndexInfo.effectIndexUnit)
  60. .set("extend_left", effectIndexInfo.extendLeft)
  61. .set("extend_right", effectIndexInfo.extendRight)
  62. .where("id = ?", effectIndexInfo.id);
  63. t.commit();
  64. ret = true;
  65. } catch (const DBException &ex) {
  66. qDebug() << ex.lastError.text();
  67. }
  68. return ret;
  69. }