Projekt

Allgemein

Profil

Herunterladen als
Herunterladen (1,93 KB) Statistiken
| Zweig: | Revision:
ed9ffe4a Christian Ehringfeld
#include "mysqlquerybuilder.h"
#include "../schema.h"

CuteEntityManager::MysqlQueryBuilder::MysqlQueryBuilder(
QSharedPointer<CuteEntityManager::Schema> schema,
QSharedPointer<CuteEntityManager::Database> database) : QueryBuilder(schema,
database) {

}

QString CuteEntityManager::MysqlQueryBuilder::renameColumn(QString tableName,
QString oldName, QString newName) const {
return "ALTER TABLE " + this->schema->quoteTableName(
tableName) + " CHANGE " +
this->schema->quoteColumnName(oldName) + " " +
this->schema->quoteColumnName(
newName);
/**
* @todo must append datatype
*/
}

QString CuteEntityManager::MysqlQueryBuilder::createIndex(QString name,
QString tableName, QStringList columns, bool unique) const {
QString s = "ALTER TABLE ";
s += this->schema->quoteTableName(tableName);
s += (unique ? "ADD UNIQUE INDEX " : "ADD INDEX ") +
this->schema->quoteTableName(
name) + " (";
s.append(this->buildColumns(columns));
s.append(");");
return s;
}

QString CuteEntityManager::MysqlQueryBuilder::dropForeignKey(QString name,
QString tableName) const {
return "ALTER TABLE " + this->schema->quoteTableName(
tableName) + " DROP FOREIGN KEY " +
this->schema->quoteColumnName(name);
}

QString CuteEntityManager::MysqlQueryBuilder::limit(const quint64 &limit,
const quint64 &offset, bool withSpace) const {
QString s = "";
if (limit > 0) {
s.append((withSpace ? " " : "") + this->limitKeyword() + " " +
QString::number(limit));
if (offset > 0) {
s.append(" " + this->offsetKeyword() + QString::number(offset));
}
} else if (offset > 0) {
s.append((withSpace ? " " : "") + this->limitKeyword() + " " +
QString::number(offset) + ", 18446744073709551615"); //2^64-1
}
return s;
}