51 lines
1.4 KiB
C++
51 lines
1.4 KiB
C++
|
|
//
|
||
|
|
// Created by Krad on 2021/11/11.
|
||
|
|
//
|
||
|
|
|
||
|
|
#include "User.h"
|
||
|
|
#include "db/SQLHelper.h"
|
||
|
|
#include <QMetaProperty>
|
||
|
|
#include <qdebug.h>
|
||
|
|
User* User::currentUser = nullptr;
|
||
|
|
|
||
|
|
User::User(QObject *parent) : QObject(parent) {
|
||
|
|
|
||
|
|
}
|
||
|
|
|
||
|
|
User::~User() {
|
||
|
|
|
||
|
|
}
|
||
|
|
|
||
|
|
bool User::submitChange() {
|
||
|
|
static QString updateSQL = "update Account %1 %2";
|
||
|
|
QString setString = "";
|
||
|
|
#define USER_READONLY_PROPERTY(name)
|
||
|
|
#define USER_PROPERTY(name)\
|
||
|
|
USER_READONLY_PROPERTY(name)\
|
||
|
|
setString += QString((!setString.isEmpty()&&mf_##name)?", ":"") + QString(mf_##name?QString("set %1='%2'").arg(#name, m_##name):"");
|
||
|
|
USER_PROPERTIES_MACRO()
|
||
|
|
#undef USER_PROPERTY
|
||
|
|
#undef USER_READONLY_PROPERTY
|
||
|
|
QString whereString = " where "+getIndexName()+" = '"+getIndexValue()+"'";
|
||
|
|
return 1 == SQLHelper::ExecuteNoQuery(updateSQL.arg(setString,whereString));
|
||
|
|
}
|
||
|
|
|
||
|
|
bool User::QueryUser(QString userID, QString Pwd) {
|
||
|
|
QString sql = QString("select * from Account where UserCode='%1' and Password='%2'")
|
||
|
|
.arg(userID).arg(Pwd);
|
||
|
|
QMap<QString,QVariant> map;
|
||
|
|
SQLHelper::Query(sql, map);
|
||
|
|
if(!map.isEmpty())
|
||
|
|
{
|
||
|
|
if (!currentUser) currentUser = new User;
|
||
|
|
#define USER_READONLY_PROPERTY(name) currentUser->m_##name = map[#name].toString();
|
||
|
|
#define USER_PROPERTY(name)\
|
||
|
|
USER_READONLY_PROPERTY(name)
|
||
|
|
USER_PROPERTIES_MACRO()
|
||
|
|
#undef USER_PROPERTY
|
||
|
|
#undef USER_READONLY_PROPERTY
|
||
|
|
return true;
|
||
|
|
}
|
||
|
|
return false;
|
||
|
|
}
|