QxSqlRelationParams.h 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  1. /****************************************************************************
  2. **
  3. ** https://www.qxorm.com/
  4. ** Copyright (C) 2013 Lionel Marty (contact@qxorm.com)
  5. **
  6. ** This file is part of the QxOrm library
  7. **
  8. ** This software is provided 'as-is', without any express or implied
  9. ** warranty. In no event will the authors be held liable for any
  10. ** damages arising from the use of this software
  11. **
  12. ** Commercial Usage
  13. ** Licensees holding valid commercial QxOrm licenses may use this file in
  14. ** accordance with the commercial license agreement provided with the
  15. ** Software or, alternatively, in accordance with the terms contained in
  16. ** a written agreement between you and Lionel Marty
  17. **
  18. ** GNU General Public License Usage
  19. ** Alternatively, this file may be used under the terms of the GNU
  20. ** General Public License version 3.0 as published by the Free Software
  21. ** Foundation and appearing in the file 'license.gpl3.txt' included in the
  22. ** packaging of this file. Please review the following information to
  23. ** ensure the GNU General Public License version 3.0 requirements will be
  24. ** met : http://www.gnu.org/copyleft/gpl.html
  25. **
  26. ** If you are unsure which license is appropriate for your use, or
  27. ** if you have questions regarding the use of this file, please contact :
  28. ** contact@qxorm.com
  29. **
  30. ****************************************************************************/
  31. #ifndef _QX_SQL_RELATION_PARAMS_H_
  32. #define _QX_SQL_RELATION_PARAMS_H_
  33. #ifdef _MSC_VER
  34. #pragma once
  35. #endif
  36. /*!
  37. * \file QxSqlRelationParams.h
  38. * \author Lionel Marty
  39. * \ingroup QxDao
  40. * \brief Define list of parameters to transfer to relationships to manage SQL queries builded by QxOrm library
  41. */
  42. #include <QtSql/qsqldatabase.h>
  43. #include <QtSql/qsqlquery.h>
  44. #include <QxDao/QxSqlJoin.h>
  45. #include <QxDao/QxSqlSaveMode.h>
  46. #include <QxCollection/QxCollection.h>
  47. namespace qx {
  48. class QxSqlRelationLinked;
  49. class IxSqlQueryBuilder;
  50. class IxSqlRelation;
  51. /*!
  52. * \ingroup QxDao
  53. * \brief qx::QxSqlRelationParams : define list of parameters to transfer to relationships to manage SQL queries builded by QxOrm library
  54. */
  55. class QX_DLL_EXPORT QxSqlRelationParams
  56. {
  57. public:
  58. typedef std::shared_ptr<QxSqlRelationLinked> type_relation_linked_ptr;
  59. typedef QHash<QString, type_relation_linked_ptr> type_lst_relation_linked;
  60. protected:
  61. QVariant m_vId; //!< Current id
  62. long m_lIndex; //!< Current SQL relation index
  63. long m_lIndexOwner; //!< Current SQL relation owner index
  64. long m_lOffset; //!< Current SQL query offset
  65. QString * m_sql; //!< Current SQL query
  66. IxSqlQueryBuilder * m_builder; //!< Current SQL query builder
  67. QSqlQuery * m_query; //!< Current SQL query connected to database
  68. QSqlDatabase * m_database; //!< Current SQL database connexion
  69. void * m_pOwner; //!< Owner to current object to resolve input/output
  70. qx::dao::sql_join::join_type m_eJoinType; //!< Current join type to build SQL query : LEFT OUTER JOIN, INNER JOIN, etc...
  71. type_lst_relation_linked * m_pRelationX; //!< Current list of relations used by qx::QxSqlRelationLinked class
  72. QString m_sTableAlias; //!< Current SQL table alias : useful for relationships defined in base class
  73. qx::dao::save_mode::e_save_mode m_eSaveMode; //!< Used to improve performance, if you know that you are just inserting or updating items in database
  74. bool m_bRecursiveMode; //!< Recursive mode to iterate over each level of relationship
  75. QSet<void *> m_lstRecursiveItems; //!< Used by recursive process to avoid infinite loop
  76. QPair<QSet<QString>, long> * m_pColumns; //!< List of relation columns to fetch (syntax : my_relation { column_1, column_2, etc... }), if empty then fetch all columns
  77. QString m_sCustomAlias; //!< Custom SQL table alias instead of generating a new one automatically
  78. QString m_sCustomAliasOwner; //!< Custom SQL table alias owner instead of generating a new one automatically
  79. public:
  80. QxSqlRelationParams();
  81. QxSqlRelationParams(long lIndex, long lOffset, QString * sql, IxSqlQueryBuilder * builder, QSqlQuery * query, void * pOwner);
  82. QxSqlRelationParams(long lIndex, long lOffset, QString * sql, IxSqlQueryBuilder * builder, QSqlQuery * query, void * pOwner, const QVariant & vId);
  83. virtual ~QxSqlRelationParams();
  84. inline QVariant id() const { return m_vId; }
  85. inline long index() const { return m_lIndex; }
  86. inline long indexOwner() const { return m_lIndexOwner; }
  87. inline long offset() const { return m_lOffset; }
  88. inline QString & sql() { qAssert(m_sql); return (* m_sql); }
  89. inline const QString & sql() const { qAssert(m_sql); return (* m_sql); }
  90. inline QSqlQuery & query() { qAssert(m_query); return (* m_query); }
  91. inline const QSqlQuery & query() const { qAssert(m_query); return (* m_query); }
  92. inline QSqlDatabase & database() { qAssert(m_database); return (* m_database); }
  93. inline const QSqlDatabase & database() const { qAssert(m_database); return (* m_database); }
  94. inline IxSqlQueryBuilder & builder() { qAssert(m_builder); return (* m_builder); }
  95. inline const IxSqlQueryBuilder & builder() const { qAssert(m_builder); return (* m_builder); }
  96. inline void * owner() const { return m_pOwner; }
  97. inline qx::dao::sql_join::join_type joinType() const { return m_eJoinType; }
  98. inline type_lst_relation_linked * relationX() const { return m_pRelationX; }
  99. inline QString getTableAlias() const { return m_sTableAlias; }
  100. inline qx::dao::save_mode::e_save_mode saveMode() const { return m_eSaveMode; }
  101. inline bool recursiveMode() const { return m_bRecursiveMode; }
  102. inline bool existRecursiveItem(void * p) const { return m_lstRecursiveItems.contains(p); }
  103. inline QSet<QString> getColumns() const { return (m_pColumns ? m_pColumns->first : QSet<QString>()); }
  104. inline bool checkColumns(const QString & s) const { return (! m_pColumns || m_pColumns->first.isEmpty() || m_pColumns->first.contains(s)); }
  105. inline long getColumnsCount() const { return (m_pColumns ? m_pColumns->first.count() : 0); }
  106. inline long getColumnsOffset() const { return (m_pColumns ? m_pColumns->second : 0); }
  107. inline QString getCustomAlias() const { return m_sCustomAlias; }
  108. inline QString getCustomAliasOwner() const { return m_sCustomAliasOwner; }
  109. inline void setId(const QVariant & vId) { m_vId = vId; }
  110. inline void setIndex(long lIndex) { m_lIndex = lIndex; }
  111. inline void setIndexOwner(long lIndex) { m_lIndexOwner = lIndex; }
  112. inline void setOffset(long lOffset) { m_lOffset = lOffset; }
  113. inline void setSql(QString * sql) { m_sql = sql; }
  114. inline void setBuilder(IxSqlQueryBuilder * builder) { m_builder = builder; }
  115. inline void setQuery(QSqlQuery * query) { m_query = query; }
  116. inline void setDatabase(QSqlDatabase * database) { m_database = database; }
  117. inline void setOwner(void * pOwner) { m_pOwner = pOwner; }
  118. inline void setJoinType(qx::dao::sql_join::join_type e) { m_eJoinType = e; }
  119. inline void setRelationX(type_lst_relation_linked * p) { m_pRelationX = p; }
  120. inline void setTableAlias(const QString & s) { m_sTableAlias = s; }
  121. inline void setSaveMode(qx::dao::save_mode::e_save_mode e) { m_eSaveMode = e; }
  122. inline void setRecursiveMode(bool b) { m_bRecursiveMode = b; }
  123. inline void insertRecursiveItem(void * p) { if (p) { m_lstRecursiveItems.insert(p); } }
  124. inline void setColumns(QPair<QSet<QString>, long> * p) { m_pColumns = p; }
  125. inline void setColumnsOffset(long l) { if (m_pColumns) { m_pColumns->second = l; } }
  126. inline void setCustomAlias(const QString & s) { m_sCustomAlias = s; }
  127. inline void setCustomAliasOwner(const QString & s) { m_sCustomAliasOwner = s; }
  128. };
  129. } // namespace qx
  130. #endif // _QX_SQL_RELATION_PARAMS_H_