本文整理汇总了C++中Constraint::SetRefColumns方法的典型用法代码示例。如果您正苦于以下问题:C++ Constraint::SetRefColumns方法的具体用法?C++ Constraint::SetRefColumns怎么用?C++ Constraint::SetRefColumns使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Constraint
的用法示例。
在下文中一共展示了Constraint::SetRefColumns方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: DisplayTables
void DatabaseCanvas::DisplayTables(std::vector<wxString> &selections, wxString &query)
{
std::vector<MyErdTable *> tables = ((DrawingDocument *)m_view->GetDocument())->GetTables();
for( std::vector<MyErdTable *>::iterator it = tables.begin(); it < tables.end(); it++ )
{
if( !IsTableDisplayed( (*it)->GetTableName() ) )
{
std::vector<Field *> fields = const_cast<DatabaseTable &>( (*it)->GetTable() ).GetFields();
m_pManager.AddShape( (*it), NULL, startPoint, sfINITIALIZE, sfDONT_SAVE_STATE );
if( (*it) == tables.back() && dynamic_cast<DrawingView *>( m_view )->GetViewType() == DatabaseView )
(*it)->Select( true );
(*it)->UpdateTable();
if( dynamic_cast<DrawingView *>( m_view )->GetViewType() == QueryView )
{
for( std::vector<Field *>::iterator it1 = fields.begin(); it1 < fields.end(); it1++ )
{
dynamic_cast<DrawingView *>( m_view )->GetWherePage()->AppendField( (*it)->GetTableName() + L"." + (*it1)->GetFieldName() );
dynamic_cast<DrawingView *>( m_view )->GetHavingPage()->AppendField( (*it)->GetTableName() + L"." + (*it1)->GetFieldName() );
}
}
wxRect rect = (*it)->GetBoundingBox();
startPoint.x += 200 + rect.GetWidth();
m_displayedTables.push_back( (*it) );
}
}
for( std::vector<MyErdTable *>::iterator it1 = m_displayedTables.begin(); it1 < m_displayedTables.end(); it1++ )
{
wxString name = const_cast<DatabaseTable &>( (*it1)->GetTable() ).GetTableName();
if( std::find( selections.begin(), selections.end(), name ) == selections.end() )
selections.push_back( name );
if( dynamic_cast<DrawingView *>( m_view )->GetViewType() == QueryView )
{
query += (*it1)->GetTableName();
if( it1 != m_displayedTables.end() - 1 )
query += ", ";
}
}
if( dynamic_cast<DrawingView *>( m_view )->GetViewType() == QueryView )
query += "\n";
// Refresh();
Constraint *pConstr = NULL;
bool found = false, secondIteration = false;
for( std::vector<MyErdTable *>::iterator it2 = tables.begin(); it2 < tables.end(); it2++ )
{
std::map<int, std::vector<FKField *> > foreignKeys = const_cast<DatabaseTable &>( (*it2)->GetTable() ).GetForeignKeyVector();
for( std::map<int, std::vector<FKField *> >::iterator it3 = foreignKeys.begin(); it3 != foreignKeys.end(); it3++ )
{
// if( ((DrawingView *) m_view)->GetViewType() == DatabaseView )
// pConstr = new DatabaseConstraint( (*it3).second );
for( std::vector<FKField *>::iterator it4 = (*it3).second.begin(); it4 < (*it3).second.end(); it4++ )
{
wxString referencedTableName = (*it4)->GetReferencedTableName();
if( std::find( selections.begin(), selections.end(), referencedTableName ) != selections.end() )
{
if( found )
secondIteration = true;
if( !found )
{
query += "WHERE ";
found = true;
}
if( ((DrawingView *) m_view)->GetViewType() == QueryView )
{
pConstr = new QueryConstraint( ((DrawingView *) m_view)->GetViewType() );
pConstr->SetLocalColumn( (*it4)->GetOriginalFieldName() );
pConstr->SetRefColumn( (*it4)->GetReferencedFieldName() );
pConstr->SetRefTable( referencedTableName );
pConstr->SetType( QueryConstraint::foreignKey );
pConstr->SetFKDatabaseTable( &(*it2)->GetTable() );
dynamic_cast<QueryConstraint *>( pConstr )->SetSign( 0 );
}
if( ((DrawingView *) m_view)->GetViewType() == DatabaseView )
{
pConstr = new DatabaseConstraint( (*it4)->GetFKName() );
pConstr->SetLocalColumns( (*it4)->GetOriginalFields() );
pConstr->SetRefColumns( (*it4)->GetReferencedFields() );
pConstr->SetLocalColumn( (*it4)->GetOriginalFieldName() );
pConstr->SetRefColumn( (*it4)->GetReferencedFieldName() );
pConstr->SetRefTable( referencedTableName );
pConstr->SetType( QueryConstraint::foreignKey );
pConstr->SetFKDatabaseTable( &(*it2)->GetTable() );
pConstr->SetPGMatch( (*it4)->GetMatchOPtion() );
}
if( dynamic_cast<DrawingView *>( m_view )->GetViewType() == QueryView )
{
if( secondIteration )
query += " AND ";
query += wxString::Format( "%s.%s = %s.%s", (*it2)->GetTableName(), (*it4)->GetOriginalFieldName(), referencedTableName, (*it4)->GetReferencedFieldName() );
}
switch( (*it4)->GetOnUpdateConstraint() )
{
case RESTRICT_UPDATE:
pConstr->SetOnUpdate( Constraint::restrict );
break;
case SET_NULL_UPDATE:
pConstr->SetOnUpdate( Constraint::setNull );
break;
case SET_DEFAULT_UPDATE:
case CASCADE_UPDATE:
pConstr->SetOnUpdate( Constraint::cascade );
//.........这里部分代码省略.........