public override void Import(string selectedNids) { DataTable Table = null; int ProgressCounter = 0; DI6SubgroupValBuilder SGBuilderObj = null; DI6SubgroupValInfo SGInfoObj = null; Dictionary <string, DataRow> FileWithNids = new Dictionary <string, DataRow>(); DIConnection SourceDBConnection = null; DIQueries SourceDBQueries = null; DI6SubgroupValBuilder SourceSGValBuilder = null; //-- Step 1: Get TempTable with Sorted SourceFileName Table = this._TargetDBConnection.ExecuteDataTable(this.ImportQueries.GetImportSubgroupVals(selectedNids)); //-- Step 2:Initialise Indicator Builder with Target DBConnection SGBuilderObj = new DI6SubgroupValBuilder(this.TargetDBConnection, this.TargetDBQueries); // Initialize progress bar this.RaiseProgressBarInitialize(selectedNids.Split(',').GetUpperBound(0) + 1); //-- Step 3: Import Nids for each SourceFile foreach (DataRow Row in Table.Copy().Rows) { try { string SourceFileWPath = Convert.ToString(Row[MergetTemplateConstants.Columns.COLUMN_SOURCEFILENAME]); SourceDBConnection = new DIConnection(DIServerType.MsAccess, String.Empty, String.Empty, SourceFileWPath, String.Empty, MergetTemplateConstants.DBPassword); SourceDBQueries = DataExchange.GetDBQueries(SourceDBConnection); // get subgroupval info from source file SourceSGValBuilder = new DI6SubgroupValBuilder(SourceDBConnection, SourceDBQueries); SGInfoObj = SourceSGValBuilder.GetSubgroupValInfo(FilterFieldType.NId, Convert.ToString(Row[MergetTemplateConstants.Columns.COLUMN_SRCNID])); SGBuilderObj.ImportSubgroupVal(Convert.ToInt32(Row[MergetTemplateConstants.Columns.COLUMN_SRCNID]), SourceDBQueries, SourceDBConnection); ProgressCounter += 1; this.RaiseProgressBarIncrement(ProgressCounter); } catch (Exception ex) { ExceptionFacade.ThrowException(ex); } finally { if (SourceDBConnection != null) { SourceDBConnection.Dispose(); } if (SourceDBQueries != null) { SourceDBQueries.Dispose(); } } } this._AvailableTable = this.GetAvailableTable(); this._UnmatchedTable = this.GetUnmatchedTable(); // Close ProgressBar this.RaiseProgressBarClose(); }
private DI6SubgroupValInfo GetSubgroupValInfo(DataRow row) { DI6SubgroupValInfo RetVal; DataTable TempTable; try { RetVal = new DI6SubgroupValInfo(); RetVal.Name = DICommon.RemoveQuotes(row[SubgroupVals.SubgroupVal].ToString()); RetVal.GID = row[SubgroupVals.SubgroupValGId].ToString(); RetVal.Global = Convert.ToBoolean(row[SubgroupVals.SubgroupValGlobal]); RetVal.Nid = Convert.ToInt32(row[SubgroupVals.SubgroupValNId]); ////get nids of age,sex,others and location //TempTable = this.SourceDBConnection.ExecuteDataTable(this.SourceDBQueries.Subgroup.GetSubgroupVals(FilterFieldType.NId, RetVal.Nid.ToString())); //if (!Microsoft.VisualBasic.Information.IsDBNull(TempTable.Rows[0][SubgroupVals.SubgroupValAge])) //{ // RetVal.Age.Nid = Convert.ToInt32(TempTable.Rows[0][SubgroupVals.SubgroupValAge]); //} //if (!Microsoft.VisualBasic.Information.IsDBNull(TempTable.Rows[0][SubgroupVals.SubgroupValSex])) //{ // RetVal.Sex.Nid = Convert.ToInt32(TempTable.Rows[0][SubgroupVals.SubgroupValSex]); //} //if (!Microsoft.VisualBasic.Information.IsDBNull(TempTable.Rows[0][SubgroupVals.SubgroupValOthers])) //{ // RetVal.Others.Nid = Convert.ToInt32(TempTable.Rows[0][SubgroupVals.SubgroupValOthers]); //} //if (!Microsoft.VisualBasic.Information.IsDBNull(TempTable.Rows[0][SubgroupVals.SubgroupValLocation])) //{ // RetVal.Location.Nid = Convert.ToInt32(TempTable.Rows[0][SubgroupVals.SubgroupValLocation]); //} } catch (Exception ex) { RetVal = null; ExceptionFacade.ThrowException(ex); } return(RetVal); }
private DI6SubgroupValInfo GetSubgroupValInfo(DataRow row) { DI6SubgroupValInfo RetVal; DataTable TempTable; try { RetVal = new DI6SubgroupValInfo(); RetVal.Name = DICommon.RemoveQuotes(row[SubgroupVals.SubgroupVal].ToString()); RetVal.GID = row[SubgroupVals.SubgroupValGId].ToString(); RetVal.Global = Convert.ToBoolean(row[SubgroupVals.SubgroupValGlobal]); RetVal.Nid = Convert.ToInt32(row[SubgroupVals.SubgroupValNId]); } catch (Exception ex) { RetVal = null; ExceptionFacade.ThrowException(ex); } return(RetVal); }