我正在修复一个C ++ Builder 5应用程序,我有这个代码:
void __fastcall TFPrincipal::DBGModuleStartDrag(TObject *Sender,
TDragObject *&DragObject)
{
m_pParentNodesDragDrop = NULL;
DragObject = NULL;
bool bAbort = false;
m_ListaModulosDragDrop->Clear();
m_ListaContenedoresDragDrop->Clear();
CInfoNode *pInfoNode = NULL;
CInfoModule *pInfoMod = NULL ;
long l_IdContainerParent = 0;
TDataSet * DataSet = NULL;
m_pLastDragNode = NULL;
m_bLastAccept = false;
try
{
IProductsPtr ProductsPtr =
m_pgServerConnection->Create<IProducts>( CLSID_CProducts );
if(DBGModules)
{
if ( DBGModules->DataSource )
{
if ( DBGModules->DataSource->DataSet )
{
DataSet = DBGModules->DataSource->DataSet;
DataSet->DisableControls();
}
else return;
}
else return;
}
else return;
for (int i = 0; i < DBGModules->SelectedCount; i++)
{
DataSet->GotoBookmark(DBGModules->SelectedRows[i].c_str());
pInfoMod = new CInfoModule( DataSet->FieldByName("IP")->AsString,
(long)DataSet->FieldByName("IdComputer")->AsInteger,
(Products)DataSet->FieldByName("IdProduct")->AsInteger,
DataSet->FieldByName("Host")->AsString,
DataSet->FieldByName("Instance")->AsString,
DataSet->FieldByName("Version")->AsString,
DataSet->FieldByName("AditionalInfo")->AsString,
(Antivirus)DataSet->FieldByName("IdAntivirus")->AsInteger,
DataSet->FieldByName("NumNotPadmin3AV")->AsInteger,
DataSet->FieldByName("NumPadmin3AV")->AsInteger,
false,
(long)DataSet->FieldByName("IdUnit")->AsInteger,
(long)DataSet->FieldByName("IdUnitForInstall")->AsInteger);
DataSet->FreeBookmark(DataSet->GetBookmark());
pInfoNode = new CInfoNode();
pInfoNode->m_pInfoModule = pInfoMod;
// Platree::TPlaTreeNode *pNodoSeleccionado = pInfoNode;
// if (pNodoSeleccionado)
{
// guardamos el padre de uno de los nodos seleccionados para
// el drag & drop para que usarlo luego para que aparezca desplegada
// la rama de origen del nodo movido y la rama de destino tras
// el refresco (parametro del ReloadTree)
// if ( ! m_pParentNodesDragDrop )
// m_pParentNodesDragDrop = pNodoSeleccionado->Parent;
//CInfoNode *pInfoNodoSeleccionado;
//pInfoNodoSeleccionado = (CInfoNode *)pNodoSeleccionado->Data;
if (pInfoNode->IsModule())
{
long l_IdContainerParent = 0;
m_ListaModulosDragDrop->AddObject(pInfoMod->m_asDisplayName,
(TObject*)pInfoNode);
/* TESTHR(ProductsPtr->GetIDContainer(pInfoMod->m_lIdComputer,
pInfoMod->m_pdIDProduct,
WideString(pInfoMod->m_asInstance),
&l_IdContainerParent));*/
CInfoDragNode *pInfoDragNode = new CInfoDragNode();
pInfoDragNode->m_asInstance = pInfoMod->m_asInstance;
pInfoDragNode->m_lIdComputer = pInfoMod->m_lIdComputer;
pInfoDragNode->m_lIdContainerParent = /*l_IdContainerParent*/0;
pInfoDragNode->m_pdIDProduct = pInfoMod->m_pdIDProduct;
m_ListaContenedoresDragDrop->Add(
reinterpret_cast<void*>(pInfoDragNode)
);
}
else
{
bAbort = true;
break;
}
}
/* delete pInfoNode;
delete pInfoMod;*/
DataSet->EnableControls();
}
if (bAbort)
{
// alguno de los items seleccionados no es un módulo
m_ListaModulosDragDrop->Clear();
}
}
catch (const nm_error::__com_error_ &e )
{
PutDebugMessage(COMError2str(e));
m_ListaModulosDragDrop->Clear();
}
}
我注意到了DataSet-&gt; GotoBookmark(DBGModules-&gt; SelectedRows [i] .c_str());正在执行缓慢。为什么会这样?使用的网格来自DevExpress
答案 0 :(得分:2)
众所周知,GotoBookmark功能以及在Delphi和C ++ Builder中使用数据集中的过滤器是一个非常严重的性能瓶颈。
我的建议是使用不同的机制跳转到所需的记录。也许只是使用查询和ID。如果无法做到这一点,请确保在用作书签键的字段上有索引。
答案 1 :(得分:1)
很可能是您的GotoBookmark导致DataSet背后的查询一次又一次地运行。根据所选行执行更具体的查询可能更好,而不是在更通用的查询的结果中转到书签。