Search code examples
c#ssisscript-component

SSIS Script Component Input0Buffer method no GetName()?


I am looking for a way to obtain my property names in a SSIS data flow task Script Component. I have been searching high and low only finding this. I have been trying to get this code to work, but I am too novice to understand what is happening here and I don't feel it is explained very well(no offense).

The source before this component is using a SQL query joining two tables. Inside the component, I would like to compare column to column. Then call an update method I created to use SqlConnection to perform the update.

public override void Input0_ProcessInputRow(Input0Buffer Row)
{
    if (Row.TableALastName != Row.TableBLastName)

        // Call the update method if the last name did not match.
        this.UpdateRecord("TableBLastName", Row.TableALastName.ToString(), Row.TableAAssociateId.ToString());
    }
}    

private void UpdateRecord(string columnName, string change, string associateId)
{
    SqlConnection sqlConnection;
    sqlConnection = new SqlConnection(this.Variables.Connection);

    string updateQuery = "UPDATE [SomeDataBase].[dbo].[TableB] SET " + columnName + " = " + change + " WHERE [Associate_ID] = " + associateId;

    using (SqlCommand cmd2 = new SqlCommand(updateQuery, sqlConnection))
    {
        sqlConnection.Open();
        cmd2.ExecuteNonQuery();
        sqlConnection.Close();
    }
}

I would like to somehow get the PropertyName of Row.TableBLastName instead of having to hard code "TableBLastName" for each test I am doing, which will be a lot.

The problem is that the input buffer class does not have Property.GetName() This also means I can't add a method to the class to get the property names, as it is regenerated each run.


Solution

  • public Input0_ProcessInputRow(Input0Buffer Row)
            {
                Dictionary<string, List<string>> list = new Dictionary<string, List<string>>();
                List<string> propertyList = new List<string>();
                Type myType = typeof(Input0Buffer);
                PropertyInfo[] allPropInfo = myType.GetProperties();
                List<PropertyInfo> SqlPropInfo = allPropInfo.Where(x => !x.Name.Contains("AM_")).ToList();
    
                // Loop through all the Sql Property Info so those without AM_
                for (int i = 0; i < SqlPropInfo.Count(); i++)
                {
                    List<string> group = new List<string>();
                    foreach (var propInfo in allPropInfo)
                    {
                        if (propInfo.Name.Contains(SqlPropInfo[i].Name))
                        {
                            // Group the values based on the property
                            // ex. All last names are grouped.
                            group.Add(propInfo.GetValue(Row, null).ToString());
                        }
                    }
    
                    // The Key is the Sql's Property Name.
                    list.Add(SqlPropInfo[i].Name, group);
                }
    
                foreach (var item in list)
                {
                    // Do a check if there are two values in both SQL and Oracle.
                    if (item.Value.Count >= 2)
                    {
                        if (item.Value.Count() != item.Value.Distinct().Count())
                        {
                            // Duplicates exist do nothing.
                        }
                        else
                        {
                            // The values are different so update the value[0]. which is the SQL Value.
                            UpdateRecord(item.Key, item.Value[0], Row.AssociateId);
                        }
                    }
                }
            }
    

    I separated the values from the two tables so there are two lists values from TableA and TableB. You can prefix the values from TableA with "AM_" or something distinct so you can use reflection to to get the properties with and without the prefix and find out which values belong to which table. Then I just loop through the properties and group the values with the properties from the target value (so those without the prefix "AM_") I then loop through the grouped list and compare the two values and if it's different, update TableA with the TableB values to match them