QxOrm
1.5.0
C++ Object Relational Mapping library
|
00001 /**************************************************************************** 00002 ** 00003 ** https://www.qxorm.com/ 00004 ** Copyright (C) 2013 Lionel Marty (contact@qxorm.com) 00005 ** 00006 ** This file is part of the QxOrm library 00007 ** 00008 ** This software is provided 'as-is', without any express or implied 00009 ** warranty. In no event will the authors be held liable for any 00010 ** damages arising from the use of this software 00011 ** 00012 ** Commercial Usage 00013 ** Licensees holding valid commercial QxOrm licenses may use this file in 00014 ** accordance with the commercial license agreement provided with the 00015 ** Software or, alternatively, in accordance with the terms contained in 00016 ** a written agreement between you and Lionel Marty 00017 ** 00018 ** GNU General Public License Usage 00019 ** Alternatively, this file may be used under the terms of the GNU 00020 ** General Public License version 3.0 as published by the Free Software 00021 ** Foundation and appearing in the file 'license.gpl3.txt' included in the 00022 ** packaging of this file. Please review the following information to 00023 ** ensure the GNU General Public License version 3.0 requirements will be 00024 ** met : http://www.gnu.org/copyleft/gpl.html 00025 ** 00026 ** If you are unsure which license is appropriate for your use, or 00027 ** if you have questions regarding the use of this file, please contact : 00028 ** contact@qxorm.com 00029 ** 00030 ****************************************************************************/ 00031 00032 #ifndef _IX_SQL_QUERY_BUILDER_H_ 00033 #define _IX_SQL_QUERY_BUILDER_H_ 00034 00035 #ifdef _MSC_VER 00036 #pragma once 00037 #endif 00038 00046 #include <QxDataMember/IxDataMemberX.h> 00047 00048 #include <QxDao/IxSqlRelation.h> 00049 #include <QxDao/QxSoftDelete.h> 00050 #include <QxDao/QxSqlRelationLinked.h> 00051 00052 namespace qx { 00053 namespace dao { 00054 namespace detail { 00055 00056 class IxDao_Helper; 00057 00058 } // namespace detail 00059 } // namespace dao 00060 } // namespace qx 00061 00062 namespace qx { 00063 00068 class QX_DLL_EXPORT IxSqlQueryBuilder 00069 { 00070 00071 private: 00072 00073 struct IxSqlQueryBuilderImpl; 00074 std::unique_ptr<IxSqlQueryBuilderImpl> m_pImpl; 00075 00076 public: 00077 00078 IxSqlQueryBuilder(); 00079 virtual ~IxSqlQueryBuilder() = 0; 00080 00081 IxDataMemberX * getDataMemberX() const; 00082 QxCollection<QString, IxDataMember *> * getLstDataMember() const; 00083 IxSqlRelationX * getLstRelation() const; 00084 qx::dao::detail::IxDao_Helper * getDaoHelper() const; 00085 void setDaoHelper(qx::dao::detail::IxDao_Helper * p); 00086 00087 void setHashRelation(const QString & s); 00088 void setCartesianProduct(bool b); 00089 QString getSqlQuery() const; 00090 QString getHashRelation() const; 00091 QString table() const; 00092 QxSoftDelete getSoftDelete() const; 00093 bool getCartesianProduct() const; 00094 long getDataCount() const; 00095 long getRelationCount() const; 00096 IxDataMember * getDataId() const; 00097 IxDataMember * nextData(long & l) const; 00098 IxSqlRelation * nextRelation(long & l) const; 00099 QString & getCurrentBuildingSql() const; 00100 00101 void initIdX(long lAllRelationCount); 00102 bool insertIdX(long lIndex, const QVariant & idOwner, const QVariant & idData, void * ptr); 00103 void * existIdX(long lIndex, const QVariant & idOwner, const QVariant & idData); 00104 void setSqlQuery(const QString & sql, const QString & key = QString()); 00105 void addSqlQueryAlias(const QString & sql, const QString & sqlAlias); 00106 bool getAddAutoIncrementIdToUpdateQuery() const; 00107 void replaceSqlQueryAlias(QString & sql) const; 00108 00109 virtual void init(); 00110 virtual void clone(const IxSqlQueryBuilder & other); 00111 virtual IxSqlQueryBuilder & buildSql(const QStringList & columns = QStringList(), QxSqlRelationLinked * pRelationX = NULL) = 0; 00112 00113 static QString addSqlCondition(const QString & sql) { return (sql.contains(" WHERE ") ? " AND " : " WHERE "); } 00114 00115 static void sql_CreateTable(QString & sql, IxSqlQueryBuilder & builder); 00116 static void sql_DeleteById(QString & sql, IxSqlQueryBuilder & builder, bool bSoftDelete); 00117 static void sql_Exist(QString & sql, IxSqlQueryBuilder & builder); 00118 static void sql_FetchAll(QString & sql, IxSqlQueryBuilder & builder); 00119 static void sql_FetchAll(QString & sql, IxSqlQueryBuilder & builder, const QStringList & columns); 00120 static void sql_FetchAll_WithRelation(qx::QxSqlRelationLinked * pRelationX, QString & sql, IxSqlQueryBuilder & builder); 00121 static void sql_FetchById(QString & sql, IxSqlQueryBuilder & builder); 00122 static void sql_FetchById(QString & sql, IxSqlQueryBuilder & builder, const QStringList & columns); 00123 static void sql_FetchById_WithRelation(qx::QxSqlRelationLinked * pRelationX, QString & sql, IxSqlQueryBuilder & builder); 00124 static void sql_Insert(QString & sql, IxSqlQueryBuilder & builder); 00125 static void sql_Update(QString & sql, IxSqlQueryBuilder & builder); 00126 static void sql_Update(QString & sql, IxSqlQueryBuilder & builder, const QStringList & columns); 00127 static void sql_Count_WithRelation(qx::QxSqlRelationLinked * pRelationX, QString & sql, IxSqlQueryBuilder & builder); 00128 00129 static void resolveOutput_FetchAll(void * t, QSqlQuery & query, IxSqlQueryBuilder & builder); 00130 static void resolveOutput_FetchAll(void * t, QSqlQuery & query, IxSqlQueryBuilder & builder, const QStringList & columns); 00131 static void resolveOutput_FetchAll_WithRelation(qx::QxSqlRelationLinked * pRelationX, void * t, QSqlQuery & query, IxSqlQueryBuilder & builder); 00132 00133 static void resolveInput_Insert(void * t, QSqlQuery & query, IxSqlQueryBuilder & builder); 00134 static void resolveInput_Update(void * t, QSqlQuery & query, IxSqlQueryBuilder & builder); 00135 static void resolveInput_Update(void * t, QSqlQuery & query, IxSqlQueryBuilder & builder, const QStringList & columns); 00136 static void resolveInput_DeleteById(void * t, QSqlQuery & query, IxSqlQueryBuilder & builder); 00137 00138 protected: 00139 00140 bool verifyColumns(const QStringList & columns) const QX_USED; 00141 00142 bool isInitDone() const; 00143 QxSoftDelete & softDelete(); 00144 const QxSoftDelete & softDelete() const; 00145 void setSoftDelete(const QxSoftDelete & o); 00146 void setDataMemberX(IxDataMemberX * p); 00147 bool findSqlQuery(const QString & key); 00148 bool findSqlAlias(const QString & key); 00149 void insertSqlAlias(const QString & key); 00150 00151 }; 00152 00153 typedef std::shared_ptr<IxSqlQueryBuilder> IxSqlQueryBuilder_ptr; 00154 00155 } // namespace qx 00156 00157 #include <QxDao/IxDao_Helper.h> 00158 00159 #endif // _IX_SQL_QUERY_BUILDER_H_