完成属性组的删除逻辑

This commit is contained in:
duanshengchao 2025-04-17 15:34:43 +08:00
parent 246df65400
commit bd49be8d6f
10 changed files with 145 additions and 13 deletions

View File

@ -23,6 +23,7 @@ public:
void setMainWindow(MainWindow*);
void addTab_attribute(const QString&, ModelAttributeGroup&);
void closeTab_attribute(ModelAttributeGroup&);
private slots:
void onTabCloseRequested(int);

View File

@ -31,6 +31,7 @@ public:
QModelIndex getConnNodeIndex(const QString& name);
void addDataModel(const QString& connection, Model& model);
void removeDataModel(DBStructureNode*);
void removeDataGroup(DBStructureNode*);
signals:
void errorOccurred(const QString& strConnectionName);

View File

@ -36,10 +36,12 @@ private:
void disconnectToDB(const QString&);
void removeNode(DBStructureNode*);
void openAttributeGroup(DBStructureNode*);
void closeAttributeGroup(DBStructureNode*);
signals:
void actionTrigger_addModel();
void openAttributeInfo(const QString&, ModelAttributeGroup&);
void closeAttributeInfo(ModelAttributeGroup&);
private slots:
void itemDoubleClick(const QModelIndex&);

View File

@ -60,6 +60,7 @@ private slots:
void onSIG_connectionStatusChanged(const QString& strConnectionName, bool bConnected);
void onSIG_addModel(Model&);
void onSIG_openAttributeInfo(const QString&, ModelAttributeGroup&);
void onSIG_closeAttributeInfo(ModelAttributeGroup&);
};
#endif // MAINWINDOW_H

View File

@ -27,6 +27,7 @@ public:
const QVector<AttributeGroup> getAttributeGroup(const QString&);
const QString getAttributeGroupName(const QString&, int);
const AttributeGroup getAttributeGroupData(const QString&, int);
bool removeAttributeGroup(const QString&, int, int);
//模型相关
const QVector<Model> getModels(const QString&);
bool addModel(const QString&, Model&);

View File

@ -80,6 +80,16 @@ void DatabaseBrowser::addTab_attribute(const QString& connection, ModelAttribute
ui->tabWidget->setCurrentIndex(index);
}
void DatabaseBrowser::closeTab_attribute(ModelAttributeGroup& attributeGroup)
{
QString tabText = attributeGroup.strModelName + "/" + attributeGroup.strGroupName;
int index = tabIndex(tabText);
if(index == -1)
return;
onTabCloseRequested(index);
}
void DatabaseBrowser::onTabCloseRequested(int index)
{
/*QObject* sender = QObject::sender();

View File

@ -212,6 +212,50 @@ void DBStructureModel::removeDataModel(DBStructureNode* modelNode)
}
}
void DBStructureModel::removeDataGroup(DBStructureNode* groupNode)
{
int groupID = groupNode->data(Qt::UserRole + NodeDataRole::ID).toInt();
//先从数据库中删除
DBStructureNode* modelNode = groupNode->parentNode();
if(!(modelNode && modelNode->type() == TableNode))
{
if(m_pMainWindow)
{
QString error = QString::fromWCharArray(L"删除失败,未找到所在链接节点信息");
m_pMainWindow->showMessageDialog(type_information, QString::fromWCharArray(L"失败"), error);
}
return;
}
int modelID = modelNode->data(Qt::UserRole + NodeDataRole::ID).toInt();
DBStructureNode* connNode = modelNode->parentNode();
if(!(connNode && connNode->type() == ConnectionNode))
{
if(m_pMainWindow)
{
QString error = QString::fromWCharArray(L"删除失败,未找到所在链接节点信息");
m_pMainWindow->showMessageDialog(type_information, QString::fromWCharArray(L"失败"), error);
}
return;
}
bool result = SqlQueryExecutor::instance().removeAttributeGroup(connNode->name(), modelID, groupID);
if(!result)
{
if(m_pMainWindow)
{
QString error = QString::fromWCharArray(L"删除失败,详情可见日志文件");
m_pMainWindow->showMessageDialog(type_information, QString::fromWCharArray(L"失败"), error);
}
return;
}
else //从列表中删除
{
QModelIndex connIndex = index(connNode->row(), 0, QModelIndex());
beginRemoveRows(index(modelNode->row(), 0, connIndex), groupNode->row(), groupNode->row());
modelNode->removeChild(groupNode);
endRemoveRows();
}
}
void DBStructureModel::refreshStructure_Connection(const QString& connection)
{
DBStructureNode* connNode = getConnectionNode(connection);

View File

@ -115,7 +115,11 @@ void DBStructureView::removeNode(DBStructureNode* node)
model->removeDataModel(node);
}
else if(node->type() == GroupNode)
{}
{
DBStructureModel* model = dynamic_cast<DBStructureModel*>(this->model());
if(model)
model->removeDataGroup(node);
}
}
void DBStructureView::openAttributeGroup(DBStructureNode* node)
@ -132,6 +136,20 @@ void DBStructureView::openAttributeGroup(DBStructureNode* node)
}
}
void DBStructureView::closeAttributeGroup(DBStructureNode* node)
{
DBStructureNode* parent = node->parentNode();
if(parent && parent->type() == TableNode)
{
int modelID = parent->data(Qt::UserRole + NodeDataRole::ID).toInt();
int groupID = node->data(Qt::UserRole + NodeDataRole::ID).toInt();
QString modelName = parent->name();
QString groupName = node->name();
ModelAttributeGroup attributeGroup(modelID, groupID, modelName, groupName);
emit closeAttributeInfo(attributeGroup);
}
}
void DBStructureView::disconnectCurConnection()
{
if(!m_curConnection.isEmpty())
@ -264,10 +282,10 @@ void DBStructureView::showContextMenu(const QPoint& pos)
});
menu.addSeparator();
menu.addAction(QString::fromWCharArray(L"刷新"), []{});
menu.addAction(QString::fromWCharArray(L"打开"), []{});
menu.addSeparator();
//menu.addAction(QString::fromWCharArray(L"打开"), []{});
/*menu.addSeparator();
menu.addAction(QString::fromWCharArray(L"清空数据"), []{});
/*menu.addAction(QString::fromWCharArray(L"导入"), []{});
menu.addAction(QString::fromWCharArray(L"导入"), []{});
menu.addAction(QString::fromWCharArray(L"导出"), []{});*/
QPoint originPoint = this->mapToGlobal(QPoint(0,0));
menu.exec(originPoint + pos);
@ -275,13 +293,31 @@ void DBStructureView::showContextMenu(const QPoint& pos)
else if(node && node->type() == GroupNode)
{
CustomMenu menu;
menu.addAction(QString::fromWCharArray(L"打开"), [this, node]{openAttributeGroup(node);});
menu.addAction(QString::fromWCharArray(L"删除"), [this, node]{
bool isPublic = node->data(Qt::UserRole + NodeDataRole::Type).toBool();
if(isPublic)
{
if(m_pMainWindow)
{
m_pMainWindow->showMessageDialog(type_warning, QString::fromWCharArray(L"错误"),
QString::fromWCharArray(L"该属性组属于必备组别,不可删除"));
}
return;
}
if(m_pMainWindow)
{
m_pMainWindow->showMessageDialog(type_question, QString::fromWCharArray(L"提示"),
QString::fromWCharArray(L"确认删除属性组 '%1' 吗").arg(node->name()));
if(g_msgDlgBtn == btn_No)
return;
}
//关闭tab(若打开)
closeAttributeGroup(node);
//移除节点
removeNode(node);
});
menu.addSeparator();
menu.addAction(QString::fromWCharArray(L"刷新"), []{});
menu.addAction(QString::fromWCharArray(L"打开"), [this, node]{openAttributeGroup(node);});
menu.addSeparator();
menu.addAction(QString::fromWCharArray(L"清空数据"), []{});
QPoint originPoint = this->mapToGlobal(QPoint(0,0));
menu.exec(originPoint + pos);

View File

@ -79,6 +79,7 @@ void MainWindow::initialize()
m_pDBStrutureView->setMainWindow(this);
connect(m_pDBStrutureView, &DBStructureView::actionTrigger_addModel, this, &MainWindow::onActionTrigger_addModel);
connect(m_pDBStrutureView, &DBStructureView::openAttributeInfo, this, &MainWindow::onSIG_openAttributeInfo);
connect(m_pDBStrutureView, &DBStructureView::closeAttributeInfo, this, &MainWindow::onSIG_closeAttributeInfo);
ui->layoutDBStructure->addWidget(m_pDBStrutureView);
m_pDBStrutureModel = new DBStructureModel(this);
m_pDBStrutureModel->setMainWindow(this);
@ -242,3 +243,9 @@ void MainWindow::onSIG_openAttributeInfo(const QString& connection, ModelAttribu
if(m_dbBrowser)
m_dbBrowser->addTab_attribute(connection, attributeGroup);
}
void MainWindow::onSIG_closeAttributeInfo(ModelAttributeGroup& attributeGroup)
{
if(m_dbBrowser)
m_dbBrowser->closeTab_attribute(attributeGroup);
}

View File

@ -134,12 +134,12 @@ QSqlQuery SqlQueryExecutor::executeBatchSQL(const QString& connectionName, const
throw DatabaseException(sqlQuery.lastError());
}
lastQuery = std::move(sqlQuery);
// 提交事务(如果已开启)
if(transactionStarted && !db.commit())
{
throw DatabaseException(db.lastError());
LOG_ERROR("DB", QString("Commit transaction failed. connectionName: %1. error: %2").arg(connectionName, db.lastError().databaseText()));
}
}
// 提交事务(如果已开启)
if(transactionStarted && !db.commit())
{
throw DatabaseException(db.lastError());
LOG_ERROR("DB", QString("Commit transaction failed. connectionName: %1. error: %2").arg(connectionName, db.lastError().databaseText()));
}
}
catch (const DatabaseException& e)
@ -344,6 +344,7 @@ bool SqlQueryExecutor::modelTypeExistsInDB(const QString& connectionName, const
bool SqlQueryExecutor::removeModel(const QString& connectionName, int modelID)
{
//数据库中有级联删除只需要从model_type中删除即可
QString strSQL = "DELETE FROM basic.model_type WHERE id = :id"/* + QString::number(modelID)*/;
QVariantHash params;
params.insert(":id", modelID);
@ -428,6 +429,34 @@ const AttributeGroup SqlQueryExecutor::getAttributeGroupData(const QString& conn
return group;
}
bool SqlQueryExecutor::removeAttributeGroup(const QString& connectionName, int modelID, int groupID)
{
//从model_attribute和model_group两个map表中对相关记录进行删除(暂时不做属性本体的删除)
QStringList sqlStatements;
QList<QVariantHash> paramsList;
sqlStatements << "DELETE FROM basic.model_attribute WHERE model_type_id = :modelID AND attribute_group_id = :groupID";
QVariantHash params;
params.insert(":modelID", modelID);
params.insert(":groupID", groupID);
paramsList << params;
sqlStatements << "DELETE FROM basic.model_group WHERE model_type_id = :modelID AND attribute_group_id = :groupID";
params.clear();
params.insert(":modelID", modelID);
params.insert(":groupID", groupID);
paramsList << params;
try
{
executeBatchSQL(connectionName, sqlStatements, paramsList, true);
}
catch (const DatabaseException& e)
{
LOG_ERROR("SQL", QString::fromWCharArray(L"删除属性组失败model_type_id:%1attribute_group_id:%2").arg(modelID, groupID));
return false;
}
return true;
}
int SqlQueryExecutor::getAttributeCount(const QString& connectionName, int modelID, int groupID)
{
int count = 0;